ES6(ECMAScript 6)新特性之模板字符串用法分析
本文實例講述了ES6(ECMAScript 6)新特性之模板字符串用法。分享給大家供大家參考,具體如下:
ES6引入了一種新型的字符串字面量語法,我們稱之為模板字符串(template strings)。除了使用反撇號字符 ` 代替普通字符串的引號 ' 或 " 外,它們看起來與普通字符串并無二致。在最簡單的情況下,它們與普通字符串的表現(xiàn)一致:
context.fillText(`Ceci n'est pas une cha?ne.`, x, y);
但我們不能說:“原來只是被反撇號括起來的普通字符串啊”。模板字符串為JavaScript提供了簡單的字符串插值功能,從此以后,你可以通過一種更加美觀、更加方便的方式向字符串中插值了。這在Java和C#中早已經(jīng)有了,不用再用 + 符號連接字符串,用起來很方便~
模板字符串的使用方式成千上萬,但最讓我暖心的是將其應(yīng)用于毫不起眼的錯誤消息提示:
function authorize(user, action) { if (!user.hasPrivilege(action)) { throw new Error( `用戶 ${user.name} 未被授權(quán)執(zhí)行 ${action} 操作。`); } }
在這個示例中,${user.name}
和${action}
被稱為模板占位符,JavaScript將把user.name和action的值插入到最終生成的字符串中,例如:用戶jorendorff未被授權(quán)打冰球。(這是真的,我還沒有獲得冰球許可證。)
到目前為止,我們所了解到的僅僅是比+運算符更優(yōu)雅的語法,下面是你可能期待的一些特性細節(jié):
模板占位符中的代碼可以是任意JavaScript表達式,所以函數(shù)調(diào)用、算數(shù)運算等這些都可以作為占位符使用,你甚至可以在一個模板字符串中嵌套另一個,我稱之為模板套構(gòu)(template inception)。
如果這兩個值都不是字符串,可以按照常規(guī)將其轉(zhuǎn)換為字符串。例如:如果action是一個對象,將會調(diào)用它的.toString()方法將其轉(zhuǎn)換為字符串值。
如果你需要在模板字符串中書寫反撇號,你必須使用反斜杠將其轉(zhuǎn)義:`\``等價于"`"。
同樣地,如果你需要在模板字符串中引入字符$和{。無論你要實現(xiàn)什么樣的目標,你都需要用反斜杠轉(zhuǎn)義每一個字符:`$`和`\{`。
與普通字符串不同的是,模板字符串可以多行書寫:
$("#warning").html(` <h1>小心!>/h1> <p>未經(jīng)授權(quán)打冰球可能受罰 將近${maxPenalty}分鐘。</p>`);
模板字符串中所有的空格、新行、縮進,都會原樣輸出在生成的字符串中。
希望本文所述對大家ECMAScript程序設(shè)計有所幫助。
相關(guān)文章
jfinal與bootstrap的登錄跳轉(zhuǎn)實戰(zhàn)演習(xí)
這篇文章給大家分享jfinal與bootstrap之間的登錄跳轉(zhuǎn),具體內(nèi)容包含有點擊登錄彈出模態(tài)框、點擊登錄確認按鈕后的validate、jfinal的validate、jfinal的session管理、ajax請求與返回信息處理、頁面間智能跳轉(zhuǎn)。感興趣的朋友跟著小編一起看看吧2015-09-09推薦幾個不錯的console調(diào)試技巧實現(xiàn)
這篇文章主要介紹了推薦幾個不錯的console調(diào)試技巧實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12微信小程序webview中監(jiān)聽返回按鈕實現(xiàn)步驟
在微信小程序中webview返回鍵是一個非常實用的功能,它允許用戶在嵌入的網(wǎng)頁中返回到上一個頁面,這篇文章主要給大家介紹了微信小程序webview中監(jiān)聽返回按鈕的實現(xiàn)步驟,需要的朋友可以參考下2024-08-08JavaScript折半查找(二分查找)算法原理與實現(xiàn)方法示例
這篇文章主要介紹了JavaScript折半查找(二分查找)算法原理與實現(xiàn)方法,結(jié)合具體問題描述了折半查找算法的原理、實現(xiàn)方法及相關(guān)操作注意事項,需要的朋友可以參考下2018-08-08