DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript技巧 >> ES6(ECMAScript 6)新特性之模板字符串用法分析
ES6(ECMAScript 6)新特性之模板字符串用法分析
編輯:JavaScript技巧     

本文實例講述了ES6(ECMAScript 6)新特性之模板字符串用法。分享給大家供大家參考,具體如下:

ES6引入了一種新型的字符串字面量語法,我們稱之為模板字符串(template strings)。除了使用反撇號字符 ` 代替普通字符串的引號 ' 或 " 外,它們看起來與普通字符串並無二致。在最簡單的情況下,它們與普通字符串的表現一致:

context.fillText(`Ceci n'est pas une cha?ne.`, x, y);

但我們不能說:“原來只是被反撇號括起來的普通字符串啊”。模板字符串為JavaScript提供了簡單的字符串插值功能,從此以後,你可以通過一種更加美觀、更加方便的方式向字符串中插值了。這在Java和C#中早已經有了,不用再用 + 符號連接字符串,用起來很方便~

模板字符串的使用方式成千上萬,但最讓我暖心的是將其應用於毫不起眼的錯誤消息提示:

function authorize(user, action) {
  if (!user.hasPrivilege(action)) {
    throw new Error(
    `用戶 ${user.name} 未被授權執行 ${action} 操作。`);
  }
}

在這個示例中,${user.name}${action} 被稱為模板占位符,JavaScript將把user.name和action的值插入到最終生成的字符串中,例如:用戶jorendorff未被授權打冰球。(這是真的,我還沒有獲得冰球許可證。)

到目前為止,我們所了解到的僅僅是比+運算符更優雅的語法,下面是你可能期待的一些特性細節:

模板占位符中的代碼可以是任意JavaScript表達式,所以函數調用、算數運算等這些都可以作為占位符使用,你甚至可以在一個模板字符串中嵌套另一個,我稱之為模板套構(template inception)。

如果這兩個值都不是字符串,可以按照常規將其轉換為字符串。例如:如果action是一個對象,將會調用它的.toString()方法將其轉換為字符串值。

如果你需要在模板字符串中書寫反撇號,你必須使用反斜槓將其轉義:`\``等價於"`"。

同樣地,如果你需要在模板字符串中引入字符$和{。無論你要實現什麼樣的目標,你都需要用反斜槓轉義每一個字符:`$`和`\{`。

與普通字符串不同的是,模板字符串可以多行書寫:

$("#warning").html(`
  <h1>小心!>/h1>
  <p>未經授權打冰球可能受罰
   將近${maxPenalty}分鐘。</p>`);

模板字符串中所有的空格、新行、縮進,都會原樣輸出在生成的字符串中。

希望本文所述對大家ECMAScript程序設計有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved