zoukankan      html  css  js  c++  java
  • bind,apply,call的区别

    在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']);
  • 相关阅读:
    Visual C# 3.0 新特性概览
    一个C#睡前故事[翻译]
    ASP.NET User Control使用技巧一则
    Visual Studio 2005 调试器的新增功能
    .NET Framework 3.0新特性
    客户端提高WEB页面显示速度的方法
    VS.Net 2005中如何:使用“编辑并继续”
    如何在 VS 2005 里调试 Javascript
    关于DotNES
    Sql语句优化汇总(CSDN上的帖子)
  • 原文地址:https://www.cnblogs.com/darrenji/p/5002852.html
Copyright © 2011-2022 走看看