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']);
  • 相关阅读:
    运维岗春招--part2
    python 题库|刷题
    leetcode刷题
    运维面经汇总
    python自动化运维阅读笔记
    Python编程汇总
    old_boy 运维学习-第一期
    团队博客作业-Week3
    个人对final发布产品的排名
    各组对final发布产品的排名
  • 原文地址:https://www.cnblogs.com/darrenji/p/5002852.html
Copyright © 2011-2022 走看看