codecamp

@babel/plugin-proposal-logical-assignment-operators

NOTE: This plugin is included in @babel/preset-env, in ES2021

Example

In

JavaScript

a ||= b;
obj.a.b ||= c;

a &&= b;
obj.a.b &&= c;

Out

JavaScript

var _obj$a, _obj$a2;

a || (a = b);
(_obj$a = obj.a).b || (_obj$a.b = c);

a && (a = b);
(_obj$a2 = obj.a).b && (_obj$a2.b = c);

With Nullish Coalescing

While using the @babel/plugin-proposal-nullish-coalescing-operator plugin (included in @babel/preset-env)

JavaScript

a ??= b;
obj.a.b ??= c;

JavaScript

var _a, _obj$a, _obj$a$b;

(_a = a) !== null && _a !== void 0 ? _a : (a = b);
(_obj$a$b = (_obj$a = obj.a).b) !== null && _obj$a$b !== void 0
? _obj$a$b
: (_obj$a.b = c);

Installation

  • npm
  • Yarn
  • pnpm
pnpm add --save-dev @babel/plugin-proposal-logical-assignment-operators

Usage

With a configuration file (Recommended)

babel.config.json

{
"plugins": ["@babel/plugin-proposal-logical-assignment-operators"]
}

Via CLI

Shell

babel --plugins @babel/plugin-proposal-logical-assignment-operators script.js

Via Node API

JavaScript

require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-proposal-logical-assignment-operators"],
});

References


@babel/plugin-syntax-top-level-await
@babel/plugin-proposal-numeric-separator
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Babel 杂项

Babel 工具软件包

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }