码迷,mamicode.com
首页 > 移动开发 > 详细

bind,apply,call的区别

时间:2015-11-28 16:47:55      阅读:143      评论:0      收藏:0      [点我收藏+]

标签:

 

在Javascript中,bind, apply, call方法都可以显式绑定上下文this,这三者有何不同呢?


bind只绑定this不马上执行

 

var person = {
    firstname: ‘darren‘,
    lastname: ‘ji‘,
    getFullName: function(){
        var fullname = this.firstname + ‘ ‘ + this.lastname;
        return fullname;
    }
};

//在浏览器中这里的this就是指向window
var logName = function(arg1, arg2){
    console.log(this.getFullName());
}

//bind只是设置了this的指向,本身并不能执行
var logPersonName = logName.bind(person);

//darren ji
logPersonName();

 


call不仅绑定this,还马上执行,并接受可变参数

 

var person = {
    firstname: ‘darren‘,
    lastname: ‘ji‘,
    getFullName: function(){
        var fullname = this.firstname + ‘ ‘ + this.lastname;
        return fullname;
    }
};

//在浏览器中这里的this就是指向window
var logName = function(arg1, arg2){
    console.log(this.getFullName());
    console.log(‘Arguments: ‘ + arg1 + ‘ ‘ + arg2);
}

//darren ji
//Arguments: en es
logName.call(person, ‘en‘,‘es‘);

 

apply不仅绑定this,也马上执行,并接受数组

 

var person = {
    firstname: ‘darren‘,
    lastname: ‘ji‘,
    getFullName: function(){
        var fullname = this.firstname + ‘ ‘ + this.lastname;
        return fullname;
    }
};

//在浏览器中这里的this就是指向window
var logName = function(arg1, arg2){
    console.log(this.getFullName());
    console.log(‘Arguments: ‘ + arg1 + ‘ ‘ + arg2);
}

//darren ji
//Arguments: en es
logName.apply(person, [‘en‘, ‘es‘]);

 

bind,apply,call的区别

标签:

原文地址:http://www.cnblogs.com/darrenji/p/5002852.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!