這篇文章主要介紹了JavaScript運算符怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
1、js屬于一種解釋性腳本語言;2、在絕大多數瀏覽器的支持下,js可以在多種平臺下運行,擁有著跨平臺特性;3、js屬于一種弱類型腳本語言,對使用的數據類型未做出嚴格的要求,能夠進行類型轉換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實現信息瀏覽或動態交互,從而有效地防止數據的丟失;5、基于對象的腳本語言,js不僅可以創建對象,也能使用現有的對象。
ECMAScript發展進程中,會有很多功能的更新,比如銷毀,箭頭功能,模塊,它們極大的改變JavaScript編寫方式,可能有些人喜歡,有些人不喜歡,但像每個新功能一樣,我們最終會習慣它們。新版本的ECMAScript引入了三個新的邏輯賦值運算符:空運算符,AND和OR運算符,這些運算符的出現,也是希望讓我們的代碼更干凈簡潔。
可選鏈接運算符(Optional Chaining Operator) 處于ES2020提案的第4階段,因此應將其添加到規范中。它改變了訪問對象內部屬性的方式,尤其是深層嵌套的屬性。它也可以作為TypeScript 3.7+中的功能使用。
相信大部分開發前端的的小伙伴們都會遇到null和未定義的屬性。JS語言的動態特性使其無法不碰到它們。特別是在處理嵌套對象時,以下代碼很常見:
if (data && data.children && data.children[0] && data.children[0].title) { // I have a title! }
上面的代碼用于API響應,我必須解析JSON以確保名稱存在。但是,當對象具有可選屬性或某些配置對象具有某些值的動態映射時,可能會遇到類似情況,需要檢查很多邊界條件。
這時候,如果我們使用可選鏈接運算符,一切就變得更加輕松了。它為我們檢查嵌套屬性,而不必顯式搜索梯形圖。我們所要做的就是使用“?” 要檢查空值的屬性之后的運算符。我們可以隨意在表達式中多次使用該運算符,并且如果未定義任何項,它將盡早返回。
對于靜態屬性用法是:
object?.property
對于動態屬性將其更改為:
object?.[expression]
上面的代碼可以簡化為:
let title = data?.children?.[0]?.title;
然后,如果我們有:
let data; console.log(data?.children?.[0]?.title) // undefined data = {children: [{title:'codercao'}]} console.log(data?.children?.[0]?.title) // codercao
這樣寫是不是更加簡單了呢? 由于操作符一旦為空值就會終止,因此也可以使用它來有條件地調用方法或應用條件邏輯
const conditionalProperty = null; let index = 0; console.log(conditionalProperty?.[index++]); // undefined console.log(index); // 0
對于方法的調用你可以這樣寫
object.runsOnlyIfMethodExists?.()
例如下面的parent對象,如果我們直接調用parent.getTitle(),則會報Uncaught TypeError: parent.getTitle is not a function錯誤,parent.getTitle?.()則會終止不會執行
let parent = { name: "parent", friends: ["p1", "p2", "p3"], getName: function() { console.log(this.name) } }; parent.getName?.() // parent parent.getTitle?.() //不會執行
與無效合并一起使用
提供了一種方法來處理未定義或為空值和表達提供默認值。我們可以使用??運算符,為表達式提供默認值
console.log(undefined ?? 'codercao'); // codercao
因此,如果屬性不存在,則可以將無效的合并運算符與可選鏈接運算符結合使用以提供默認值。
let title = data?.children?.[0]?.title ?? 'codercao'; console.log(title); // codercao
expr1 ??= expr2
邏輯空值運算符僅在空值(空值或未定義)時才將值分配給expr1,表達方式:
x ??= y
可能看起來等效于:
x = x ?? y;
但事實并非如此!有細微的差別。
空的合并運算符(??)從左到右操作,如果x不為空,則短路。因此,如果x不為null或未定義,則永遠不會對表達式y進行求值。因此,如果y是一個函數,它將根本不會被調用。因此,此邏輯賦值運算符等效于
x ?? (x = y);
此邏輯賦值運算符僅在左側表達式為 falsy值時才賦值。Falsy與null有所不同,因為falsy可以是任何一種值:false,0,“”,null,undefined和NaN等
語法
x ||= y
等同于
x || (x = y)
在我們想要保留現有值(如果不存在)的情況下,這很有用,否則我們想為其分配默認值。例如,如果搜索請求中沒有數據,我們希望將元素的內部HTML設置為默認值。否則,我們要顯示現有列表。這樣,我們避免了不必要的更新和任何副作用,例如解析,重新渲染,失去焦點等。我們可以簡單地使用此運算符來使用JavaScript更新HTML:
document.getElementById('search').innerHTML ||= '<i>No posts found matching this search.</i>'
可能你已經猜到了,此邏輯賦值運算符僅在左側為真時才賦值。因此:
x &&= y
等同于
x && (x = y)
感謝你能夠認真閱讀完這篇文章,希望小編分享的“JavaScript運算符怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。