中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript運算符優先級是什么

發布時間:2020-12-07 13:44:08 來源:億速云 閱讀:194 作者:小新 欄目:web開發

這篇文章給大家分享的是有關JavaScript運算符優先級是什么的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

寫了兩年的JavaScript的我,原以為是不會在語法上陰溝里翻船的,可是事實上被打臉,最近在產品開發中組里的一個帥小伙找我討論一個問題,為了方便大家閱讀,我將這個問題的模型抽象出來:

var provider = {
    test: {
        $get: function(){
            return function anonymous(config){
            };
        }
    }
};
var type = "test";
var config = {};
new provider[type].$get()(config);

上面的語句運行時候為什么函數anonymous中的this指向的是window而不是new創建的新對象。我當時聽到這個問題的第一時刻想的是: 納尼 !怎么可能new操作符對應的構造函數中的this指向的不是新創建的對象實例呢?當時由于并沒有仔細地將問題從業務中抽象出來,其實我也有點迷糊,但仔細一想,這個語句到底要表達什么呢?

思考

在說這個表達式所要表達的含義之前,先說一個關于new操作符的幾個小知識:

構造函數的返回

JavaScript構造函數中可以返回值,也可以不返回值,比如:

function Person(){

}
var person = new Person()

我們知道這個時候構造函數返回的是創建的實例對象,也就是構造函數中this所指向的對象。但是當你構造函數有返回值時,就要分情況區分。如果返回的是一個非引用類型的值時,實際上返回的是仍然是新創建的實例對象。但是當返回的是一個引用類型的值時,返回的是引用對象本身。比如:

function Person(){
    return function(){}
}
var person = new Person()
typeof person // "function"

在JavaScript中函數作為一等公民,實質上就是引用類型,因此person就是返回的匿名函數。

new操作符的兩種形態

其實在MDN的new操作符描述中,語法是

new constructor[([arguments])]

你會發現([arguments])被中括號所包圍也就意味著可缺省,因此,如果對于不含參數的構造函數而言:new Person()與new Person二者并無區別,那我們接著思考一個問題,對于前面返回函數的Person而言,當new Person()的時候為什么執行的是new Person()而不是(new Person)()呢。之前如果閱讀過我之前的一篇文章的同學知道,帶有參數的new操作符的優先級大于無參數列表的new操作符。因此總是會執行第一種而不是第二種。

JavaScript運算符優先級是什么

了解上面的步驟之后,我們已經接近了問題的本質,對于表達式

new provider[type].$get()(config);

JavaScript引擎到底是解析成:

(new provider[type].$get())(config);

還是

new (provider[type].$get())(config);

對于第一種形式而言,(new provider[type].$get())返回的是anonymous函數,因此在anonymous(config)中內部this指向是window。而第二種模式中provider[type].$get()返回的是anonymous函數,因此運行new anonymous(config)時內部的this指針指向的是新創建的實例this。

當然我們從問題: this為什么指向的是window而不是new創建的新對象中可以看出來,其實作者當時想要表達的是第二種含義,但實際上卻以第一種方式在運行。為什么?原因非常簡單,第一種執行方式JavaScript引擎首先解析的是帶參數列表的的new操作符,而第二種方式則是先執行了函數調用,再執行的是new操作符,我們對照上面的優先級圖可以看到,帶參數列表的new優先級高于函數調用,因此肯定是以第一種方式去運行。

其實這篇文章并沒有多少干貨,但是從中還是有兩點感悟吧,第一,從上一篇同類文章中我就強調避免使用這種模糊不清的表達式,多用幾個括號一切問題都迎刃而解,比如有的同學會寫出類似于:

var str = "Hello" + true ? "World" : "JavaScript";

那請問str內容是什么呢,有的人可能認為是Hello World,有的人會認為是World,實質上運算的結果是World,
因為+運算符優先級是高于條件運算符的,這時候添加括號會讓你的代碼變得更加易于閱讀。第二,保持對技術的敬畏吧,最怕的就是你覺得你都會了,其實你一無所知。

感謝各位的閱讀!關于JavaScript運算符優先級是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

敦化市| 沛县| 武宣县| 东方市| 虞城县| 稻城县| 隆尧县| 新龙县| 府谷县| 长海县| 余干县| 腾冲县| 大同市| 莱阳市| 百色市| 澄迈县| 昭平县| 武宁县| 娄烦县| 德惠市| 府谷县| 台东市| 河池市| 兴化市| 天津市| 天门市| 阿鲁科尔沁旗| 大关县| 特克斯县| 安新县| 鄂伦春自治旗| 长子县| 德庆县| 娱乐| 铜川市| 阿图什市| 邵东县| 和龙市| 娱乐| 汾西县| 望谟县|