浅谈javascript 函数属性和方法

每个函数都包含两个属性:length 和 prototype length:当前函数希望接受的命名参数的个数 prototype:是保存他们所有实力方法的真正所在

代码如下:
一个 alert(sum.length);//2 参数个数2个 alert(sayHi.length);//0 没有参数

每个函数都包含两个非继承而来的方法:apply() 和 call() 这两个方法都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值 首先apply()接受两个参数:一个函数运行的作用域,另一个参数数组(可以是数组实例也可以是arguments对象)

代码如下:

其次,call方法一个参数没有变化,变化的是其余的参数都是传递参数,传递给函数的参数需要逐个列举出来

代码如下:

至于使用哪个方法更方便,完全取决于你的意愿。如果没有参数,用哪个都一样。 但是,apply和call方法的出现绝对不是只是为了怎样去船体参数。 它们真正的用武之地在于扩充函数赖以运行的作用域。

代码如下:

使用apply和call来扩充作用域的最大的好处就是不需要与方法有任何的耦合关系。

ECMAScript5 还定义了一个方法:bind()。这个方法会创建一个函数的实例,其this值会被绑定到传给bind函数的值

代码如下:

以上就是本文的全部内容,希望小伙伴们能够喜欢。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...