zoukankan      html  css  js  c++  java
  • JavaScript Function.call() 函数详解

    语法

    functionObject.call( [ thisObj [, arg1 [, arg2 [, args...]]]] )

    call()函数用于调用当前函数functionObject,并可同时使用指定对象thisObj作为本次执行时functionObject函数内部的this指针引用。

    该函数属于Function对象,所有主流浏览器均支持该函数。

    参数

    参数描述
    thisObj 可选/Object类型指定执行functionObject函数时,函数内部this指针引用的对象。
    arg1 可选/任意类型调用functionObject函数时传入的第1个参数。
    arg2 可选/任意类型调用functionObject函数时传入的第2个参数。
    args 可选/任意类型调用functionObject函数时传入的更多参数,可以有多个。

    如果为该函数所属的functionObject对象提供了传入参数,则必须提供thisObj参数。

    备注:该函数与Function对象的apply()函数作用相同,只不过call()函数是将Function对象的参数一个个分别传入,apply()函数是将Function对象的参数以一个数组或arguments对象的形式整体传入。

    返回值

    call()方法的返回值为任意类型,其返回值取决于当前functionObject对象的返回值。

    示例&说明

    name = "张三";
    age = 18;
    
    function test(){
        document.writeln(this);
        document.writeln(this.name);
        document.writeln(this.age);     
    };
    
    // 全局函数内部的this默认为全局对象window
    test(); // [object Window] 张三 18
    
    
    var obj = {name: "李四", age: 20};
    // 更改内部的this指针引用对象为obj
    test.call(obj); // [object Object] 李四 20
    
    
    function foo(a, b){
        document.writeln(this.name);    
        document.writeln(a);    
        document.writeln(b);    
    }
    // 改变this引用为obj,同时传递两个参数
    foo.call(obj, 12, true); // 李四 12 true
    
    
    function bar(a, b){
        var o = {name: "王五"};
        // 调用foo()函数,并改变其this为对象o,传入参数a,b作为其参数
        foo.call(o, a, b);  
    }
    bar("CodePlayer", "www.365mini.com"); // 王五 CodePlayer www.365mini.com
    运行代码
  • 相关阅读:
    DIV+CSS—菜鸟分享学习心得!入门篇
    有关 JavaScript 的 10 件让人费解的事情
    [论离职]走的人不少,来的人更多
    面朝电脑,春暖花开
    职场小说:《米亚快跑》PDF版下载
    flex和html的对比
    10个可以简化开发过程的MySQL工具
    转:大型网站架构不得不考虑的10个问题
    怎样善用色彩层次?40个精彩站点给你灵感
    50个令人耳目一新的网页纹理设计
  • 原文地址:https://www.cnblogs.com/dehuachenyunfei/p/6650889.html
Copyright © 2011-2022 走看看