现在的位置: 首页 > 综合 > 正文

javascript函数对象的内部方法call(), apply(), bind()

2016年02月27日 ⁄ 综合 ⁄ 共 851字 ⁄ 字号 评论关闭

今天完成javascript中函数的对象的最后一个知识点。 

函数对象的内部方法call(), apply(), bind()

相关阅读:

这三个函数都是指向函数本身的,call()apply()的第一参数都是这个函数要执行的上下文对象,之后的参数是这个函数执行要传的参数,不同的地方时call是以枚举的方式传参,apply是以数组的形式传参,当然也可以传递arguments对象。bind()是把该函数绑定到指定的context上下文执行环境中,简单讲就是把该函数的this对象指向传到bind()中的参数context,并返回一个函数实例

简单的写个示例代码我们就可以了然了:

  1.     function sayHi(name,greeting){
        var name = name||this.name,
        greeting = greeting||this.greeting;
        console.log("Hello "+name+","+greeting);
        }
         
        var name = "Terry",
        greeting = "how are you?",
        me = {name:"John",
        greeting:"你好!"};
        sayHi.call(this,name,greeting);
        sayHi.call(this);
        sayHi.apply(this,[name,greeting]);
        sayHi.apply(me,[me.name,me.greeting]);
        sayHi.call(me,me.name,me.greeting);
        //bind()会返回函数实例,后面加()直接执行
        sayHi.bind()();
        sayHi.bind(me)();

 执行结果:

 javascrip函数详解到此结束,有没有讲到的,欢迎指出,相互学习。

抱歉!评论已关闭.