美文网首页
前端new Function()的用法

前端new Function()的用法

作者: QDzzzhy | 来源:发表于2019-05-05 00:28 被阅读0次

在使用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;
    }

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

相关文章

  • 前端new Function()的用法

    在使用JavaScript时,大家一般都会怎样创建函数?我相信大部分都是这样的: 今天在学习ES6的时候发现了一种...

  • Promise

    一.Promise常见用法 function doSth() { return New Promise(func...

  • javascript中function(){}(),new fu

    javascript中function(){}(),new function(),new Function(),F...

  • new Function()

    第一种方式 第二种方式 第三种方式 我们甚至不需要显式地传参数给这个函数。我们使用apply方法来调用它。它会自动...

  • new function

    先看看熟悉一点的写法: new function(){} 与 new Function()的区别 奇怪 有趣

  • new Function

    1、eval中的代码执行时的作用域为当前作用域。它可以访问到函数中的局部变量。*2、new Function中的代...

  • bluebird

    Core new Promise(Function

  • 函数的声明方式

    1.函数构造器 new Function(……) 不常用 var add = new Function("firs...

  • function用法

    声明函数 function命令 1.具名函数 传入参数f(3,4),输出7。 2.匿名函数 + var 3.具名函...

  • 小程序绘制多张网络图片

    downfile:function(url){ return new Promise(function(res...

网友评论

      本文标题:前端new Function()的用法

      本文链接:https://www.haomeiwen.com/subject/zwyqoqtx.html