js中不常見的運算符與操作符總結
javaScript常用運算符和操作符總結
類別 |
操作符 |
算術操作符 | +、 –、 *、 /、 %(取模) |
字符串操作符 | + 字符串連接 +=字符串連接復合 |
布爾操作符 | !、 &&、 || |
一元操作符 | ++ 、 -- 、 +(一元加)、 -(一元減) |
關系比較操作符 | < 、 <= 、 > 、>=、 != 、 == 、 === 、 !== |
按位操作符 | ~ 按位非 &按位與 | 按位或 ^按位異或 <<左移 >>有符號右移 >>>無符號右移 |
賦值操作符 | = 、 復合賦值(+=、-=、*=、%=) 復合按位賦值(~=、&=、|=、^=、<<=、>>=、>>>=) |
對象操作符 | .屬性訪問、[]屬性或數(shù)組訪問、 new調用構造函數(shù)常見對象、delete變量屬性刪除、void(返回undefined)、in判斷屬性、instanceof原型判斷 |
其它操作符 | ?: 條件操作符、,逗號操作符、()分組操作、typeof類型操作符 |
js中不常見的運算符與操作符
空值合并運算符: ??
當左側的操作數(shù)為 null 或者 undefined 時,返回其右側操作數(shù),否則返回左側操作數(shù)。
null ?? 'huli' // huli undefined ?? 'huli' // undefined '' ?? 'huli' // '' [] ?? 'huli' // [] ({}) ?? 'huli' // {} NaN ?? 'huli' // NaN false ?? 'huli' // false 0 ?? 'huli' // 0
邏輯空賦值: ??=
邏輯空賦值運算符 (x ??= y) 僅在 x 是 nullish (null 或 undefined) 時對其賦值。
const a = { duration: 50 }; a.duration ??= 10; console.log(a.duration); // expected output: 50 a.speed ??= 25; console.log(a.speed); // expected output: 25
邏輯或: ||
存在真則為真, , 以前面的為準
const a = 3; const b = -2; console.log(a > 0 || b > 0); // true
可以是false的值
null
undefined
NaN
"" 與 ''
0
false
邏輯或賦值: ||=
有則返回,沒有則賦值
const a = { duration: 50, title: '' }; a.duration ||= 10; console.log(a.duration); // expected output: 50 a.title ||= 'title is empty.'; console.log(a.title); // expected output: "title is empty"
邏輯與: &&
都存在則為真, 以后面的為準
const a = 3; const b = -2; console.log(a > 0 && b > 0); // expected output: false
邏輯與賦值: &&=
存在則賦值
let a = 1; let b = 0; a &&= 2; console.log(a); // expected output: 2 b &&= 2; console.log(b); // expected output: 0
可選鏈操作符: ?.
可選鏈操作符( ?. )允許讀取位于連接對象鏈深處的屬性的值,而不必明確驗證鏈中的每個引用是否有效。?. 操作符的功能類似于 . 鏈式操作符,不同之處在于,在引用為空(nullish ) (null 或者 undefined) 的情況下不會引起錯誤,該表達式短路返回值是 undefined。與函數(shù)調用一起使用時,如果給定的函數(shù)不存在,則返回 undefined。
const adventurer = { name: 'Alice', cat: { name: 'Dinah' } }; const dogName = adventurer.dog?.name; console.log(dogName); // expected output: undefined console.log(adventurer.someNonExistentMethod?.()); // expected output: undefined
總結
到此這篇關于js中不常見的運算符與操作符的文章就介紹到這了,更多相關js運算符與操作符內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用layui實現(xiàn)的左側菜單欄以及動態(tài)操作tab項方法
今天小編就為大家分享一篇使用layui實現(xiàn)的左側菜單欄以及動態(tài)操作tab項方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09TypeScript中d.ts類型聲明文件的實現(xiàn)
.d.ts 文件是 TypeScript 的類型聲明文件,它們的主要作用是為 JavaScript 庫提供類型支持,本文主要介紹了TypeScript中d.ts類型聲明文件的實現(xiàn),感興趣的可以了解一下2023-10-10JavaScript正則表達式替換字符串中圖片地址(img src)的方法
這篇文章主要介紹了JavaScript正則表達式替換字符串中圖片地址(img src)的方法,結合實例形式分析了JS正則替換的常用技巧與注意事項,需要的朋友可以參考下2017-01-01