百科狗-知识改变命运!
--

Function - JavaScript Function 对象

梵高1年前 (2023-11-21)阅读数 23#技术干货
文章标签函数

Function

每个 JavaScript 函数实际上都是一个Function对象。运行(function(){}).constructor === Function // true便可以得到这个结论。

构造函数

Function()(en-US)

创建一个新的Function对象。直接调用此构造函数可以动态创建函数,但会遇到和eval()类似的的安全问题和(相对较小的)性能问题。然而,与eval()不同的是,Function构造函数创建的函数只能在全局作用域中运行。

实例属性

Function.prototype.arguments已弃用

Function - JavaScript Function 对象

对应传递给函数的参数数组,这个Function的属性已被弃用,请改用arguments对象(仅在函数范围内可用)。

Function.prototype.caller已弃用

表明调用当前函数执行的函数,此属性已被弃用,且仅对一些不严格的函数可用。

Function.prototype.displayName

函数的显示名称。

Function.prototype.length

函数期望的参数数量。

Function.prototype.name

函数的名称。

实例方法

Function.prototype.apply(thisArg[,argsArray])

调用一个函数并将其this的值设置为提供的thisArg。参数可用以通过数组对象传递。

Function.prototype.bind(thisArg[,arg1[,arg2[,...argN]]])

创建一个新的函数,该函数在调用时,会将this设置为提供的thisArg。在调用新绑定的函数时,可选的参数序列([, arg1[, arg2[,...argN]]])会被提前添加到参数序列中(译者注:即调用绑定创建的函数时,传递的参数会接续在可选参数序列后)。

Function.prototype.call(thisArg[,arg1,arg2,...argN])

调用一个函数,并将其this值设置为提供的值。也可以选择传输新参数。

Function.prototype.toString()

返回表示函数源码的字符串。覆盖了Object.prototype.toString方法。

示例

Function 构造函数与函数声明之间的不同

Function构造函数创建的函数不会创建当前环境的闭包,它们总是被创建于全局环境,因此在运行时它们只能访问全局变量和自己的局部变量,不能访问它们被Function构造函数创建时所在的作用域的变量。这一点与使用eval()执行创建函数的代码不同。

var x = 10;

function createFunction1() {
    var x = 20;
    return new Function('return x;'); // 这里的 x 指向最上面全局作用域内的 x
}

function createFunction2() {
    var x = 20;
    function f() {
        return x; // 这里的 x 指向上方本地作用域内的 x
    }
    return f;
}

var f1 = createFunction1();
console.log(f1());          // 10
var f2 = createFunction2();
console.log(f2());          // 20
Copy to Clipboard

虽然这段代码可以在浏览器中正常运行,但在 Node.js 中f1()会产生一个“找不到变量x”的ReferenceError。这是因为在 Node 中顶级作用域不是全局作用域,而x其实是在当前模块的作用域之中。

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)