【騷操作系列】一、如何通過babel配置使用可選鏈`?.`和雙問號(hào)`??`

如何通過babel配置使用可選鏈?.和雙問號(hào)??

什么是可選鏈

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Optional_chaining
當(dāng)訪問多層對(duì)象屬性(如o.a.b)時(shí)钝凶,如果屬性a為空娜庇,則會(huì)報(bào)引用錯(cuò)誤
為此我們不得不這么處理:

const c = o.a && o.a.b ? o.a.b : undefined

有了可選鏈炫贤,就可以對(duì)一個(gè)為null或者undefined屬性安全引用:

const o = {}

const tryA_B = o?.a?.b
console.log(tryA_B) // undefined

什么是雙問號(hào)

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Nullish_coalescing_operator

value1 ?? value2

??value1value2之間再登,只有當(dāng)value1null或者 undefined時(shí)取value2尔邓,否則取value10,false,""被認(rèn)為是有意義的,所以還是取value1

const o = {}
const c_or_d = o.c ?? 'd'
console.log(c_or_d) // 'd'
console.log(0 ?? 1) // 0
console.log("" ?? "foo") // ""

等價(jià)于

const c_or_d = (o.c === null || typeof o.c === "undefined") ? o.c : 'd'

如何使用

首先檢查你的項(xiàng)目依賴中的babel版本锉矢,如果你的babel版本<7梯嗽,那么很遺憾,你得先解決babel版本升級(jí)的問題沽损。
如果是babel7以上的版本灯节,可以添加以下2個(gè)devDependencies依賴:

@babel/plugin-proposal-optional-chaining // 可選鏈
@babel/plugin-proposal-nullish-coalescing-operator // 雙問號(hào)

然后在.babelrc或者babel.config.js中這加入2個(gè)插件(plugins屬性放在JSON頂層):

{
 "plugins": [
    "@babel/plugin-proposal-nullish-coalescing-operator",
    "@babel/plugin-proposal-optional-chaining"
  ]
}

之后就可以愉快地使用了!

最簡(jiǎn)實(shí)踐

為了檢驗(yàn)插件是否真的有用缠俺,這里提供一個(gè)最小實(shí)踐示例:
首先編寫示例代碼 index.js

var foo = {
    a: 1,
    zero: 0,
}

var fooA = foo.a;
var fooB = foo?.b;
var fooNilValue = foo?.nil?.value;

var fooDefault = foo.default ?? 'default value';
var fooZeroDefault = foo.zero ?? 'zero value';

console.log(fooA); // 1
console.log(fooB); // undefined
console.log(fooNilValue); // undefined
console.log(fooDefault); // default value
console.log(fooZeroDefault); // 0

項(xiàng)目根目錄下初始化npm倉庫 npm init显晶,然后安裝下列依賴(現(xiàn)在是2020年了贷岸,默認(rèn)都是7以上的版本):

npm i --save-dev @babel/cli @babel/core @babel/preset-env

項(xiàng)目根目錄添加配置文件 babel.config.js 壹士,不用加別的,可選鏈和雙問號(hào)插件會(huì)根據(jù)你的語法自動(dòng)轉(zhuǎn)義:

module.exports = {
    presets: [
        "@babel/preset-env"
    ]
}

執(zhí)行編譯命令:

npx babel index.js -d dist

構(gòu)建完畢偿警,在./dist/index.js 中看到生成的文件躏救,說明編譯成功:

"use strict";

var _foo$nil, _foo$default, _foo$zero;

var foo = {
  a: 1,
  zero: 0
};
var fooA = foo.a;
var fooB = foo === null || foo === void 0 ? void 0 : foo.b;
var fooNilValue = foo === null || foo === void 0 ? void 0 : (_foo$nil = foo.nil) === null || _foo$nil === void 0 ? void 0 : _foo$nil.value;
var fooDefault = (_foo$default = foo["default"]) !== null && _foo$default !== void 0 ? _foo$default : 'default value';
var fooZeroDefault = (_foo$zero = foo.zero) !== null && _foo$zero !== void 0 ? _foo$zero : 'zero value';
console.log(fooA);
console.log(fooB);
console.log(fooNilValue);
console.log(fooDefault);
console.log(fooZeroDefault);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市螟蒸,隨后出現(xiàn)的幾起案子盒使,更是在濱河造成了極大的恐慌,老刑警劉巖七嫌,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件少办,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡诵原,警方通過查閱死者的電腦和手機(jī)英妓,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绍赛,“玉大人蔓纠,你說我怎么就攤上這事÷鸢觯” “怎么了腿倚?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)蚯妇。 經(jīng)常有香客問我敷燎,道長(zhǎng)暂筝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任硬贯,我火速辦了婚禮乖杠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘澄成。我一直安慰自己胧洒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布墨状。 她就那樣靜靜地躺著卫漫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪肾砂。 梳的紋絲不亂的頭發(fā)上列赎,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音镐确,去河邊找鬼包吝。 笑死,一個(gè)胖子當(dāng)著我的面吹牛源葫,可吹牛的內(nèi)容都是我干的诗越。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼息堂,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼嚷狞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起荣堰,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤床未,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后振坚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體薇搁,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年渡八,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了啃洋。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡呀狼,死狀恐怖裂允,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情哥艇,我是刑警寧澤绝编,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響十饥,放射性物質(zhì)發(fā)生泄漏窟勃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一逗堵、第九天 我趴在偏房一處隱蔽的房頂上張望秉氧。 院中可真熱鬧,春花似錦蜒秤、人聲如沸汁咏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽攘滩。三九已至,卻和暖如春纸泡,著一層夾襖步出監(jiān)牢的瞬間漂问,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國(guó)打工女揭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蚤假,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓吧兔,卻偏偏與公主長(zhǎng)得像磷仰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子掩驱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容