{ PH_Dev }

Published on

ES6 模板字串(Template literals)

Authors
  • avatar
    Name
    Penghua Chen(PH)
    Twitter

ES6 模板字串(Template literals)

今天要來學習的部分是 ES6 好用的語法,模板字串(Template literals)

這個語法大大增加了開發的效率,是個非常好用的技巧,讓我們趕緊學起來吧!

ES6之前新增字串的方式

在ES6之前我們新增字串的方式是透過 ' ' 以及 + 作為字串間串連的橋樑,程式碼大致如下:

var name = "Bill";
console.log('Hi, my name is:' + name);

透過上述的方式可以讓變數的值與字串搭配運用。

但如果今天字串的內容是一段HTML架構呢?

  var className = container;
  var string  = '<div class="'+ className +'"></div>'

如果字串是一組HTML架構時,這時候可讀性跟開發效率肯定就不會太好。

不過自從有了ES6 的模板字串(Template literals)後,這個問題就大幅度的被改善囉

ES6之後新增字串的方式

關於使用模板字串(Template literals)有幾種常見的方式:

//1. 第一種
`string text`

//2. 第二種
`string text line 1
 string text line 2`

//3. 第三種
`string text ${expression} string text`

模板字串(Template literals)

簡單透過一個反引號,就可以輕鬆的將 HTML 架構呈現:

var string = `
  <ul class="list">
    <li>123</li>
    <li>456</li>
    <li>789</li>
    <li>101</li>
  </ul>
`;

那如果有變數時,這時候只需要透過 ${...} 就可以輕鬆將需要的變數放入到字串中囉:

var className = "list-li";
var string = `
  <ul class="list">
    <li class=${className}>123</li>
    <li class=${className}>456</li>
    <li class=${className}>789</li>
    <li class=${className}>101</li>
  </ul>
`;

但其實 ${...} 的好用之處可不只這些,從 MDN 提供的語法來看可以發現,剛剛用於放入變數的地方,其實是可以放入一個表達式(expression)的,換句話說,我們也可以這麼使用:

var a = 1;
var b = 2;
console.log(`Total : ${a + b}`);

${a + b} 中的 a + b 是一個表達式(expression),所以可以使用。

或者我們也可以放入條件判斷:

function buyCar(name,money){
  console.log(`${name} ${(money > 500000) ? 'can buy a car.':'can not afford it.'}`)
}

buyCar('Jack',700000);