new Function的用法

在使用JavaScript时,大家一般都会怎样创建函数?我相信大部分都是这样的:

function foo(arg1,arg2...){
	...
}

今天在学习ES6的时候发现了一种以前没有尝试过的写法,具体如下:

	let str = 'return ' + '`Hello ${name}!`';
	let func = new Function('name', str);
	func('Jack') // "Hello Jack!"

当看到这里的时候我是懵逼的,为什么传入了两个字符串?下面我为大家解析一下:

大家肯定都知道new Function ,因为大家都用过new Array等方法,那么我们是否考虑过其底部原理是什么?

其实,new Function的实现是这样的:
var function_name=new function(arg1,arg2,...,argN,function_body)

其中arg1,arg2直到argN就是我们需要传递的形参,可以有任意个,最后一个function_body就是我们希望函数执行的函数体,这里函数体必须放在最后,而且参数和函数体都必须用字符串的形式写入。

现在让我们再分析一下上面的代码

	let str = 'return ' + '`Hello ${name}!`';		//关于${name}可以搜索ES6模板字符串进行了解
	let func = new Function('name', str);
	func('Jack') // "Hello Jack!"
	//第二行代码中,第一个参数name表示形参,需要我们调用时传递,第二个参数str是我们自定义的一个字符串"return hello ${name}!",这就相当于如下写法
	function func(name){
		return "hello" + name;
	}

记录每天的学习体会,如有错误或建议,请及时指正。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值