js中Function引用类型常见有用的方法和属性详解
2019-12-12 12:10
176 查看
Function类型
函数由于是Function类型的一个实例,所以函数名就是一个指向函数对象的指针,不会与某个函数死死的连接在一起,这也导致了js中没有真正的重载,但好处是,函数对象可以作为另一个函数的参数或是返回值;
访问一个函数对象的指针而不是执行函数本身不能加括号
var func = new Function("x", "y", "return x + y");// 构造函数来实例化一个Function类型, 但不推荐使用 function func(x, y){ return x + y; }// 函数声明 js引擎会将所有的函数声明提升到顶部 var func = function (x, y){ return x + y };// 函数表达式 变量的赋值, 变量func保存着 function(x, y){ return x + y} 这个对象
Function类型中,有两个特殊的对象:arguments和this , 前者里面有传入函数中所有的参数,还有一个callee属性,这是个指针指向拥有这个属性的Function实例;而this这个指针指向执行环境,也就是Global类型的一个实例. 在浏览器中是一个窗口.
function b(){ console.log(arguments.callee); }
Function类型的属性和方法
length // Funciton实例期望接收形式参数的个数 prototype // apply();// 非继承的方法 // apply(Function实例运行的作用域:this, Array实例或arguments) call();// 非继承的方法 // call(Function实例运行的作用域:this, arg1, arg2, ...) // bind( X );// 将Function的实例的this指向 对象 X
除此之外,Function类型中还有一个特殊的属性:caller,这是个指针,在严格模式下不能对这个属性赋值.
Function类型一个实例a调用了Function类型的另一个实例b, 那么实例b中的caller属性就会指向实例a;
function a(){ b(); } function b(){ console.log(arguments.callee.caller); }
以上就是本次介绍的全部相关知识点,感谢大家的学习和对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- js中判断Object、Array、Function等引用类型对象是否相等的方法
- js中Function有用的属性和方法
- NET-OOP:.属性、方法、值类型和引用类型
- js的基本数据类型 引用类型 以及常见的内置对象
- js window常见属性和方法
- js面向对象之公有、私有、静态属性和方法详解
- 【JavaScript】基本数据类型与引用数据类型区别(及为什么String、Boolean、Number基本数据类型会有属性和方法?)
- 属性,引用数据类型和方法参数
- js中的四种类型的属性、方法,以及闭包的概念
- 引用:JS判断浏览器类型方法
- 4.2、JS——var 数据类型 节点标签属性操作 动态获取方法
- 在js中基本类型与引用类型的详解
- 关于基本类型和引用类型的值传递以及function方法的参数传递
- JS数据类型和引用类型详解(转发)
- Vue.js计算机属性computed和methods方法详解
- 微信小程序引用公共js里的方法的实例详解
- 【JS】引用类型之Function
- 引用 JS判断浏览器类型方法
- 由js apply与call方法想到的js数据类型(原始类型和引用类型)
- 对js中的引用类型的理解(4)——Function类型