91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

淺談ES6 模板字符串的具體使用方法

發布時間:2020-09-01 21:28:12 來源:腳本之家 閱讀:133 作者:見見 欄目:web開發

寫在前面

關于 ES6, 也終于在 2015 年的 7 月 18 號塵埃落定了。雖然說各大瀏覽器還沒有全面的支持,不過這并不妨礙我們一顆想要擼一把的心。在后端,可以使用 Node.js(0.12+)或 io.js, 前端的話,也可以使用Babel 或Traceur 進行語法預轉義成 ES5使用 。

關于該系列(不知道能不能成為一個系列,總是各種懶),會沒有規律的挑選一些內容來學習。歡迎大家積極糾錯,留言探討。

模板字符串(template strings)

用法

// 普通字符串
`In JavaScript '\n' is a line-feed.`

// 多行字符串
`In JavaScript this is
not legal.`

// 字符串中嵌入變量
var name = "Bob", time = "today";
`Hello ${name}, how are you ${time}?`  // Hello Bob, how are you today?

ES6 中引進的一種新型的字符串字面量語法 - 模板字符串。書面上來解釋,模板字符串是一種能在字符串文本中內嵌表示式的字符串字面量。簡單來講,就是增加了變量功能的字符串。

先來看一下以前我們對字符串的使用:

/**
 * Before ES6 字符串拼接
 */
var name = '丁香醫生';
var desc = '丁香醫生是面向大眾的科普性健康類網站';
var html = function(name, desc){
  var tpl = '公司名:' + name + '\n'+
      '簡介:'+ desc;
  return tpl;
}

而現在:

var html = `公司名:${name}
  簡介:${desc}`;

很簡潔吧。

引一段 MDN 對于模板字符串的定義:

模板字符串使用反引號 () 來代替普通字符串中的用雙引號和單引號。模板字符串可以包含特定語法(${expression})的占位符。占位符中的表達式和周圍的文本會一起傳遞給一個默認函數,該函數負責將所有的部分連接起來。

而占位符${},可以是任意的 js 表達式(函數或者運算),甚至是另一個模板字符串,會將其計算的結果作為字符串輸出。如果模板中需要使用$,{等字符串,則需要進行轉義。

看個例子就明白了。

var x = 1;
var y = 2;
`${ x } + ${ y } = ${ x + y}` // "1 + 2 = 3"

不同于普通字符串,模板字符串還可以多行書寫,模板字符串中所有的空格,新行,縮進都會原樣的輸出在生成的字符串中。

而單純的模板字符串還存在著很多的局限性。如:

  1. 不能自動轉義特殊的字符串。(這樣很容易引起注入攻擊)
  2. 不能很好的和國際化庫配合(即不會格式化特定語言的數字,日期,文字等)
  3. 沒有內建循環語法,(甚至連條件語句都不支持, 只可以使用模板套構的方法)

標簽模板(tagged template)

為此,引出了標簽模板的概念。標簽模板則是在反引號前面引入一個標簽(tag)。該標簽是一個函數,用于處于定制化模板字符串后返回值。就拿上面對特殊字符串舉例。

/**
 * HTML 標簽轉義
 * @param {Array.<DOMString>} templateData 字符串類型的tokens
 * @param {...} ..vals 表達式占位符的運算結果tokens
 * 
 */
function SaferHTML(templateData) {
 var s = templateData[0];
 for (var i = 1; i < arguments.length; i++) {
  var arg = String(arguments[i]);
  // Escape special characters in the substitution.
  s += arg.replace(/&/g, "&amp;")
      .replace(/</g, "&lt;")
      .replace(/>/g, "&gt;");
  // Don't escape special characters in the template.
  s += templateData[i];
 }
 return s;
}
// 調用
var html = SaferHTML`<p>這是關于字符串模板的介紹</p>`;

標簽函數會接收多個參數。

  1. 第一個參數是包含了字符串字面量(即那些沒有變量替換的值)的數組
  2. 后面的參數是已經替換后的變量值

改一下例子1

var name = '丁香醫生';
var desc = '丁香醫生是面向大眾的科普性健康類網站';
tag`公司名:${name}簡介:${desc}`

tag 的參數則分別為 ['公司名:','簡介:'], '丁香醫生', '丁香醫生是面向大眾的科普性健康類網站'。

有了此類方法,就大大的增加了控制的權利。如上面說的國際化庫甚至循環語句。

瀏覽器兼容性

  1. 服務器端, io.js 支持
  2. 瀏覽器端, FF34+ , chrome 41+
  3. 移動端 IOS 8, Android 4.4
  4. IE Tech Preview

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西丰县| 耿马| 香格里拉县| 洮南市| 循化| 永登县| 应用必备| 海宁市| 长白| 钟山县| 三都| 郴州市| 屯留县| 神木县| 当涂县| 玉门市| 盱眙县| 云林县| 广州市| 黔西县| 界首市| 延津县| 永善县| 玉屏| 乌兰察布市| 石屏县| 同德县| 太仆寺旗| 巴塘县| 宜良县| 金昌市| 望奎县| 龙江县| 灵石县| 聂拉木县| 高清| 华阴市| 宜春市| 准格尔旗| 伊吾县| 江门市|