<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        JavaScript 中的 this 簡單規則

        來源:懂視網 責編:小采 時間:2020-11-27 22:29:37
        文檔

        JavaScript 中的 this 簡單規則

        JavaScript 中的 this 簡單規則:幾條規則確定函數里的 this 是什么。 想確定 this 是什么其實非常簡單。總體的規則是,通過檢查它的調用位置,在函數被調用的的時候確定 this。它遵循下面這些規則,接下來以優先級順序說明。 規則 1、如果在調用函數時使用 new 關鍵字,那么函數里的 thi
        推薦度:
        導讀JavaScript 中的 this 簡單規則:幾條規則確定函數里的 this 是什么。 想確定 this 是什么其實非常簡單。總體的規則是,通過檢查它的調用位置,在函數被調用的的時候確定 this。它遵循下面這些規則,接下來以優先級順序說明。 規則 1、如果在調用函數時使用 new 關鍵字,那么函數里的 thi

        幾條規則確定函數里的 this 是什么。

        想確定 this 是什么其實非常簡單。總體的規則是,通過檢查它的調用位置,在函數被調用的的時候確定 this。它遵循下面這些規則,接下來以優先級順序說明。

        規則

        1、如果在調用函數時使用 new 關鍵字,那么函數里的 this 就是一個全新的對象。

        function ConstructorExample() {
         console.log(this);
         this.value = 10;
         console.log(this);
        }
        new ConstructorExample();
        // -> {}
        // -> { value: 10 }

        2、如果使用 apply、call 或者 bind 調用函數,那么函數里的 this 就是作為參數傳進去的對象。

        function fn() {
         console.log(this);
        }
        var obj = {
         value: 5
        };
        var boundFn = fn.bind(obj);
        boundFn(); // -> { value: 5 }
        fn.call(obj); // -> { value: 5 }
        fn.apply(obj); // -> { value: 5 }

        3、如果函數作為一個方法調用,就是說如果使用點符號調用函數,那么 this 就是擁有這個函數作為屬性的對象。換句話說,當一個點在函數調用的左側時,this 就是這個點左側的那個對象。

        var obj = {
         value: 5,
         printThis: function() {
         console.log(this);
         }
        };
        obj.printThis(); // -> { value: 5, printThis: ƒ }

        4、如果函數作為一個純粹的函數調用,也就是說,它在沒有上述任何條件的情況下被調用,那么 this 就是全局對象。在瀏覽器里,就是 window 對象。

        function fn() {
         console.log(this);
        }
        // 如果在瀏覽器里調用:
        fn(); // -> Window {stop: ƒ, open: ƒ, alert: ƒ, ...}

        注意這個規則其實和第三個規則是一樣的,區別在于沒有聲明為方法的函數會自動成為全局對象 window 的屬性。因此,這其實是一個隱式的方法調用。當我們調用 fn(),其實就會被瀏覽器理解為 window.fn(),所以 this 就是 window。

        console.log(fn === window.fn); // -> true

        5、如果上述規則有多個適用,那么優先級更高的就會設置 this 值。

        6、如果是 ES2015 里的箭頭函數,那么它將忽略上述所有規則,并在創建的時候接收包含它的作用域作為 this 的值。想確定 this 具體是什么的話,只需從創建箭頭函數那里往上一行,看看那兒的 this 是什么,箭頭函數里的 this 值和它一樣。

        const obj = {
         value: 'abc',
         createArrowFn: function() {
         return () => console.log(this);
         }
        };
        const arrowFn = obj.createArrowFn();
        arrowFn(); // -> { value: 'abc', createArrowFn: ƒ }

        看回第三個規則,當我們調用 obj.createArrowFn() 的時候,createArrowFn 里的 this 是 obj,因為這是方法調用。因此,obj 會在 arrowFn 里綁定到 this 上。如果我們在全局作用域創建一個箭頭函數,那么 this 值就會是 window。

        應用規則

        讓我們來看一個代碼示例,并應用這些規則。嘗試一下看能否弄清楚不同的函數調用下,this 是什么。

        確定應用了哪條規則

        var obj = {
         value: 'hi',
         printThis: function() {
         console.log(this);
         }
        };
        var print = obj.printThis;
        obj.printThis(); // -> {value: "hi", printThis: ƒ}
        print(); // -> Window {stop: ƒ, open: ƒ, alert: ƒ, ...}

        obj.printThis() 屬于第三條規則,方法調用。另一方面,print() 屬于第四條規則,純粹的函數調用。對于 print() 來說,我們在調用的時候沒有使用 new、bind/call/apply 或者點符號,所以它對應了規則四,this 就是全局對象 window。

        當適用多個規則的時候

        當適用多個規則的時候,使用列表里更高優先級的規則。

        var obj1 = {
         value: 'hi',
         print: function() {
         console.log(this);
         },
        };
        var obj2 = { value: 17 };

        如果規則二和規則三同時適用,那么規則二占優。

        obj1.print.call(obj2); // -> { value: 17 }

        如果規則一和規則三同時適用,那么規則一占優。

        new obj1.print(); // -> {}

        有些庫有時候會故意將 this 值綁定到某些函數里。而通常會在函數里將最有用的值綁定到 this 上使用。舉個例子,jQuery 把 this 綁定到 DOM 元素上,在回調中觸發一個事件。如果某個庫出現一個不太符合上述規則的 this 值,那么請仔細閱讀這個庫的文檔,它很有可能使用 bind 綁定了。

        總結

        以上所述是小編給大家介紹的JavaScript 中的 this 簡單規則,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        JavaScript 中的 this 簡單規則

        JavaScript 中的 this 簡單規則:幾條規則確定函數里的 this 是什么。 想確定 this 是什么其實非常簡單。總體的規則是,通過檢查它的調用位置,在函數被調用的的時候確定 this。它遵循下面這些規則,接下來以優先級順序說明。 規則 1、如果在調用函數時使用 new 關鍵字,那么函數里的 thi
        推薦度:
        標簽: 中的 里的 規則
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 男人j进女人p免费视频| 亚洲男人天堂2022| 成人久久久观看免费毛片| 在线天堂免费观看.WWW| 亚洲国产成人无码av在线播放| 88av免费观看入口在线| 久久精品国产亚洲av高清漫画| 亚洲一区二区三区免费观看 | **实干一级毛片aa免费| 日韩亚洲Av人人夜夜澡人人爽 | 免费一区二区三区| 亚洲AV日韩AV永久无码下载| 久久久久久AV无码免费网站| 久久久亚洲AV波多野结衣| 99久久免费国产香蕉麻豆| 亚洲日本人成中文字幕| 国产做床爱无遮挡免费视频| 免费人成又黄又爽的视频在线电影| 亚洲精品天堂成人片?V在线播放| 好猛好深好爽好硬免费视频| 久久久久亚洲av无码专区导航| 成人免费毛片内射美女-百度| 欧洲亚洲国产精华液| 亚洲人成色7777在线观看| 99xxoo视频在线永久免费观看| 亚洲一线产品二线产品| 亚洲国产黄在线观看| 亚洲一区二区在线免费观看| 亚洲色最新高清av网站| 在线日韩日本国产亚洲| 69视频在线是免费观看| 99亚洲男女激情在线观看| 亚洲Av永久无码精品三区在线| 成人免费午夜无码视频| 一区二区免费国产在线观看| 亚洲美免无码中文字幕在线| 日韩免费观看一级毛片看看| 免费国产成人午夜在线观看| 中文字幕无码精品亚洲资源网久久| 亚洲人成人网站在线观看| 久久久久久毛片免费播放|