• call,apply,bind——js权威指南函数属性和方法章节读书笔记


    每个函数(即这两个方法是函数的方法)都包含两个非继承而来的方法: apply()和 call()。参数明确,使用call。参数不明确,使用apply,可以遍历数组参数
    1,call里面的参数是散开的,apple.say.call(banana,arg_0,arg_1)
    2,apply里面的参数是数组形式的,apple.say.apply(banana,[arg_0,arg_1])
     
    window.color = "red";
    var o = { color: "blue" };
    function sayColor(){
    alert(this.color);
    }
    sayColor(); //red
    sayColor.call(this); //red
    sayColor.call(window); //red
    sayColor.call(o); //blue
    3,bind是创建一个函数的实例,参数是this指向的对象。
    window.color = "red";
    var o = { color: "blue" };
    function sayColor(){
    alert(this.color);
    }
    var objectSayColor = sayColor.bind(o);//创造了一个实例
    objectSayColor();
     
    总体举例:
    var obj = {
    x: 81,
    };
     
    var foo = {
    getX: function() {
    return this.x;
    }
    }
     
    console.log(foo.getX.bind(obj)()); //81
    console.log(foo.getX.call(obj)); //81
    console.log(foo.getX.apply(obj)); //81
    三个输出的都是81,但是注意看使用 bind() 方法的,他后面多了对括号。
     
    也就是说,区别是,当你希望改变上下文环境之后并非立即执行,而是回调执行的时候,使用 bind() 方法。而 apply/call 则会立即执行函数。
     
    总结一下:
     
    apply 、 call 、bind 三者都是用来改变函数的this对象的指向的;
    apply 、 call 、bind 三者第一个参数都是this要指向的对象,也就是想指定的上下文;
    apply 、 call 、bind 三者都可以利用后续参数传参;
    bind是返回对应函数,便于稍后调用;apply、call则是立即调用 。
     

  • 相关阅读:
    C# 读取 vCard 格式
    C#自动选择出系统中最合适的IP地址
    WPF专业编程指南
    WPF专业编程指南
    随手复习一下委托:delegate
    迟到的 WPF 学习 —— 控件
    迟到的 WPF 学习 —— 路由事件
    迟到的 WPF 学习 —— 依赖项属性
    迟到的 WPF 学习 —— 布局
    JavaScript 左右上下自动晃动,自动移动。
  • 原文地址:https://www.cnblogs.com/yaoyao-sun/p/10387834.html
Copyright © 2020-2023  润新知