首頁 > web前端 > js教程 > 主體

apply和call的方法介紹

零下一度
發布: 2017-06-29 13:37:09
原創
913 人瀏覽過

apply和call的方法是一模一樣的,都是用來改變方法的this關鍵字,並且把方法執行:而且在嚴格模式和非嚴格模式下對於第一個參數是null/undefined這種情況的規律是一樣的;

bind:這個方法在IE6-8下不相容->和call和apply類似都是用來改變this關鍵字的

'use strict' //告诉当前浏览器接下来的js代码将按照严格模式进行编写var obj = {name:'张三'}function fn(num1,num2){
            console.log(num1+num2);
            console.log(this)
        }
        fn(100,200);
        //this ->window num1=100 num2=200fn.call(100,200);
        // this->100 num1 = 200 num2=undefined  NaNfn.call(obj,100,200)
        //this->obj  call在给fn传递参数的时候,是一个个传递值的,而apply不是一个个传,而是把要传递的参数值放在一个数组中进行操作。但是也相当于一个个的给fn的形参赋值fn.apply(obj,[100,200]);
        //        
         //预处理:事先把fn的this改变为我们想要的结果,并且把对应的参数值也准备好,以后要用到了,直接的执行即可。bind这里实现了预处理的效果var tempFn = fn.bind(obj,100,200);
        //只是改变了fn中的this为obj,并且给fn传递了两个参数值100和200,但此时并没有把fn这个函数执行,执行bind会有一个返回值,这个返回值tempFn就是我们把fn的this改变后的那个结果        
        tempFn();
        fn.call();
        //this->window  在严格模式下this->undefinedfn.call(null);
        //this->window 在严格模式下this->nullfn.call(undefined)
        //this->window 在严格模式下this->undefined
登入後複製

以上是apply和call的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板