ECMAScript發展進程中,會有很多功能的更新,比如銷毀,箭頭功能,模塊,它們極大的改變JavaScript編寫方式,可能有些人喜歡,有些人不喜歡,但像每個新功能一樣,我們最終會習慣它們。新版本的ECMAScript引入了三個新的邏輯賦值運算符:空運算符,AND和OR運算符,這些運算符的出現,也是希望讓我們的代碼更干凈簡潔,下面分享幾個優雅的JavaScript運算符使用技巧
一、可選鏈接運算符【?.】
可選鏈接運算符(Optional Chaining Operator) 處于ES2020提案的第4階段,因此應將其添加到規范中。它改變了訪問對象內部屬性的方式,尤其是深層嵌套的屬性。它也可以作為TypeScript 3.7+中的功能使用。
相信大部分開發前端的的小伙伴們都會遇到null和未定義的屬性。JS語言的動態特性使其無法不碰到它們。特別是在處理嵌套對象時,以下代碼很常見:
1
2
3
|
if (data && data.children && data.children[0] && data.children[0].title) { // I have a title! } |
上面的代碼用于API響應,我必須解析JSON以確保名稱存在。但是,當對象具有可選屬性或某些配置對象具有某些值的動態映射時,可能會遇到類似情況,需要檢查很多邊界條件。
這時候,如果我們使用可選鏈接運算符,一切就變得更加輕松了。它為我們檢查嵌套屬性,而不必顯式搜索梯形圖。我們所要做的就是使用“?” 要檢查空值的屬性之后的運算符。我們可以隨意在表達式中多次使用該運算符,并且如果未定義任何項,它將盡早返回。
對于靜態屬性用法是:
1
|
object?.property |
對于動態屬性將其更改為:
1
|
object?.[expression] |
上面的代碼可以簡化為:
1
|
let id="codetool">
然后,如果我們有:
這樣寫是不是更加簡單了呢? 由于操作符一旦為空值就會終止,因此也可以使用它來有條件地調用方法或應用條件邏輯
對于方法的調用你可以這樣寫
例如下面的parent對象,如果我們直接調用parent.getTitle(),則會報Uncaught TypeError: parent.getTitle is not a function錯誤,parent.getTitle?.()則會終止不會執行
與無效合并一起使用 提供了一種方法來處理未定義或為空值和表達提供默認值。我們可以使用??運算符,為表達式提供默認值
因此,如果屬性不存在,則可以將無效的合并運算符與可選鏈接運算符結合使用以提供默認值。
|