JS 关于 bind ,call,apply 和arguments p8

关于这3个货,网上有不少文章介绍,我这边仍是记录下并加上本身的理解,还有arguments函数内置对象顺便也记录下:git

 

简单的说apply和call 会绑定第一个参数的做用域给调用函数对象实例,并会执行调用函数,还能够传参数github

apply 第二个参数是数组,call 是可变长度参数express

apply、call:数组

例子来个:app

function x(t,v){
     console.log(this.id);
     if(t){
         console.log(t);
     }
     if(v){
         console.log(v);
     }
}

var id = '我是外部ID';

var obj = { id:'我是内部obj的ID' }

x(); //我是外部ID

x.apply(obj); // 我是内部obj的ID

x.call(obj); // 我是内部obj的ID

x.apply(obj,['test']);
 //     我是内部obj的ID
 //     test


x.call(obj,'test','test2');
 //     我是内部obj的ID
 //     test
 //     test2

是否是一下就明白了。ide

 

bind:函数

bind一样会绑定,也会穿参数,可是不会当即执行性能

x.bind(obj)() ; // 我是内部obj的ID

var x_copy = x.bind(obj);
x_copy();//我是内部obj的ID

 

arguments:this

相似数组,但不是真的数组,好吧,就把它当成数组吧,它一样拥有length 并且也能够经过下标访问:spa

function x(){
   console.log(arguments.length);
   
   var j = 0;
   for(let i=0;i<arguments.length;i++){
       j += arguments[i];
   }

   console.log('[j >>]',j);
} ;

x();
// 0
// [j >>] undefined

x(1);
// 1
// [j >>] 1

x(1,2);
// 2
// [j >>] 3

 

关于arguments.callee():

下面的官方语言:
警告:严格模式下,第5版 ECMAScript (ES5) 禁止使用 arguments.callee()。当一个函数必须调用自身的时候, 避免使用 arguments.callee(), 经过要么给函数表达式一个名字,要么使用一个函数声明.

很少写,有兴趣的能够去这看看

arguments.callee

若是须要调用自身可使用函数表达式(下面是官方的例子):

[1,2,3,4,5].map(function factorial (n) {
    return !(n > 1) ? 1 : factorial(n-1)*n;
});
  • 该函数能够像代码内部的任何其余函数同样被调用
  • 它不会在外部做用域中建立一个变量 (除了 IE 8 及如下)
  • 它具备比访问arguments对象更好的性能

总之,官方都废弃了,你还执着啥?

相关文章
相关标签/搜索