Noah Lemen 40805894c5 default to spec mode for template literal transform (#6098)
* spec/loose/default switch for template literal transform, update/re-org tests

* update readme

* flip if statements

* consolidate else/if

* readme wording modification, updates to examples
2017-08-28 12:57:09 -06:00

1.4 KiB

babel-plugin-transform-es2015-template-literals

Compile ES2015 template literals to ES5

Example

In

`foo${bar}`;

Out

"foo".concat(bar);

Installation

npm install --save-dev babel-plugin-transform-es2015-template-literals

Usage

.babelrc

Without options:

{
  "plugins": ["transform-es2015-template-literals"]
}

With options:

{
  "plugins": [
    ["transform-es2015-template-literals", {
      "loose": true
    }]
  ]
}

Via CLI

babel --plugins transform-es2015-template-literals script.js

Via Node API

require("babel-core").transform("code", {
  plugins: ["transform-es2015-template-literals"]
});

Options

loose

boolean, defaults to false.

When true, tagged template literal objects aren't frozen. All template literal expressions and quasis are combined with the + operator instead of with String.prototype.concat.

When false or not set, all template literal expressions and quasis are combined with String.prototype.concat. It will handle cases with Symbol.toPrimitive correctly and throw correctly if template literal expression is a Symbol(). See babel/babel#5791.

In

`foo${bar}`;

Out

"foo" + bar;