摘要:新特性異步迭代器正則表達(dá)式反向斷言正則表達(dá)式轉(zhuǎn)義非轉(zhuǎn)義序列的模板字符串本文正則表達(dá)式模式正則表達(dá)式命名捕獲組對象展開運(yùn)算符這個提案由負(fù)責(zé),目前已經(jīng)進(jìn)入,本提案是的一部分。因此標(biāo)準(zhǔn)移除了對在帶標(biāo)簽的模版字符串中轉(zhuǎn)義序列的語法限制。
ES2018 新特性
異步迭代器
正則表達(dá)式反向(lookbehind)斷言
正則表達(dá)式 Unicode 轉(zhuǎn)義
非轉(zhuǎn)義序列的模板字符串(本文)
正則表達(dá)式 s/dotAll 模式
正則表達(dá)式命名捕獲組
對象展開運(yùn)算符
Promise.prototype.finally
這個 ECMAScript 提案 “Template Literal Revision” 由 Tim Disney 負(fù)責(zé),目前已經(jīng)進(jìn)入 stage 4,本提案是 ECMAScript 2018(ES9) 的一部分。該提案讓我們使用模板字符串的標(biāo)簽函數(shù)語法更加的自由。
1. 標(biāo)簽函數(shù) Tagged templates標(biāo)簽使您可以用函數(shù)解析模板字符串。標(biāo)簽函數(shù)的第一個參數(shù)包含一個字符串值的數(shù)組。其余的參數(shù)與表達(dá)式相關(guān)。最后,你的函數(shù)可以返回處理好的的字符串(或者它可以返回完全不同的東西)。
function foo(str) { return str[0].toUpperCase(); } foo`justjavac`; // 輸出 JUSTJAVAC foo`Xyz`; // 輸出 XYZ2. String.raw()
String.raw() 是一個模板字符串的標(biāo)簽函數(shù),它的作用類似于 Python 中的字符串前綴 r 和 C# 中的字符串前綴 @,是用來獲取一個模板字符串的原始字面量值的。
語法:
String.raw(callSite, ...substitutions) String.raw`templateString`
String.raw() 是唯一一個內(nèi)置的模板字符串標(biāo)簽函數(shù)。
var str = String.raw`Hi ${2+3}!`; // "Hi 5!" str.length; // 字符串長度為 6 str.split("").join(","); // 分隔字符串 // 結(jié)果是:"H,i,,n,5,!"3. 原始字符串
在標(biāo)簽函數(shù)的第一個參數(shù)中,存在一個特殊的屬性 raw,我們可以通過它來訪問模板字符串的原始字符串,而不經(jīng)過特殊字符的替換。
function foo(str) { console.log(str); return str[0].toUpperCase(); } foo`justjavac`; // 控制臺輸出 ["justjavac", raw: ["justjavac"]] foo`justjavac`; // 控制臺輸出 ["justjavac", raw: ["justjavac"]]4. 帶標(biāo)簽函數(shù)的轉(zhuǎn)義序列
自 ES2016 起,帶標(biāo)簽的模版字面量遵守以下轉(zhuǎn)義序列的規(guī)則:
Unicode字符以"u"開頭,例如 u00A9
Unicode碼位用"u{}"表示,例如 u{2F804}
十六進(jìn)制以"x"開頭,例如 xA9
八進(jìn)制以""和數(shù)字開頭,例如 251
對于每一個 ECMAScript 語法,解析器都會去查找有效的轉(zhuǎn)義序列,對于無效的轉(zhuǎn)義序列,直接拋出 SyntaxError:
String.raw``; Uncaught SyntaxError: Unterminated template literal5. ES2018 關(guān)于非法轉(zhuǎn)義序列的修訂
帶標(biāo)簽函數(shù)的模版字符串應(yīng)該允許嵌套支持常見轉(zhuǎn)義序列的語言(例如 DSLs、LaTeX)。
因此 ECMAScript 2018 標(biāo)準(zhǔn)移除了對 ECMAScript 在帶標(biāo)簽的模版字符串中轉(zhuǎn)義序列的語法限制。
function tag(strs) { strs[0] === undefined strs.raw[0] === "unicode and u{55}"; } // 在標(biāo)簽函數(shù)中使用 tag`unicode and u{55}`; // 結(jié)果是 undefined // 不在標(biāo)簽函數(shù)中使用 let bad = `bad escape sequence: unicode`; // throws early error:SyntaxError: Invalid Unicode escape sequence6. 實現(xiàn)
V8 - Chrome 62
SpiderMonkey - Firefox 53
JavaScriptCore - 版本未知
ChakraCore - 開發(fā)中
Babel - 7.x
7. 相關(guān)鏈接:https://github.com/tc39/propo...
https://tc39.github.io/propos...
https://developer.mozilla.org...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/93145.html
摘要:或者使用來匹配空白字符增加標(biāo)志在最新的規(guī)范中,為的正則表達(dá)式增加了一個新的標(biāo)志用來表示。標(biāo)志用于指定多行輸入字符串應(yīng)該被視為多個行。標(biāo)志只影響和標(biāo)志只影響目前在正則表示中所有修飾符的含義實現(xiàn) ES2018 新特性 異步迭代器 正則表達(dá)式反向(lookbehind)斷言 正則表達(dá)式 Unicode 轉(zhuǎn)義 非轉(zhuǎn)義序列的模板字符串 正則表達(dá)式 s/dotAll 模式(本文) 正則表達(dá)式命...
摘要:不幸的是,迭代器不能用來表示這樣的數(shù)據(jù)源。即使是的迭代器也是不夠的,因為它的是異步的,但是迭代器需要同步確定狀態(tài)。異步迭代器一個異步迭代器就像一個迭代器,除了它的方法返回一個的。 ES2018 新特性 異步迭代器(本文) 正則表達(dá)式反向(lookbehind)斷言 正則表達(dá)式 Unicode 轉(zhuǎn)義 非轉(zhuǎn)義序列的模板字符串 正則表達(dá)式 s/dotAll 模式 正則表達(dá)式命名捕獲組 對...
摘要:為了使程序員能夠一次一個地處理集合中的元素,引入了迭代器接口。迭代器使用該方法獲取對象屬性名稱的數(shù)組,然后將其分配給常量。迭代器的缺點是它們不適合表示異步數(shù)據(jù)源。每次循環(huán)時,都會調(diào)用迭代器的方法,它返回一個。 前言 原文地址:https://css-tricks.com/new-es2018-features-every-javascript-developer-should-kno...
閱讀 723·2023-04-25 17:54
閱讀 2980·2021-11-18 10:02
閱讀 1140·2021-09-28 09:35
閱讀 660·2021-09-22 15:18
閱讀 2862·2021-09-03 10:49
閱讀 3060·2021-08-10 09:42
閱讀 2584·2019-08-29 16:24
閱讀 1263·2019-08-29 15:08