How can I write a template literal in ECMAScript 6 that will contain backticks(`) in and by itself, (i.e. nested backticks)?
For example:
var qu
ES6 has new features:
Which make working with strings easier. You wrap your text in `backticks`.
With this we can:
Interpolate variables
let foo = "abc";
console.log(`Welcome ${foo}`); // Welcome abc
Interpolate any kind of expression
console.log(`2+3 = ${2+3}`) // 2+3 = 5
Declare strings with both ' and " quotation marks without having to escape anything.
let foo = `foo is 'bar', "bar" is foo`
console.log(foo); // "foo is 'bar', "bar" is foo"
Cleaner syntax for multi-line string
let text = `foo is bar
bar is foo`
console.log(text);
//"foo is bar
//bar is foo"
Tagged templates, we can pass template literals to a function, here is how:
let person = 'Mike';
let age = 28;
let output = myTag `that ${ person } is ${ age }`;
function myTag(strings, personExp, ageExp) {
// strings[0] gets value "that "
// strings[1] gets value " is "
// personExp gets value " Mike "
// ageStr gets value "28"
return strings[0] + personExp + strings[1] + ageExp;
}
console.log(output);
// that Mike is 28
String.raw, we can get the raw form, here is the example:
let text = String.raw `The "\n" newline won't result in a new line.'
console.log(text);
// The "\n" newline won't result in a new line.