成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ES6學(xué)習(xí)摘要(03)(新人學(xué)習(xí))

番茄西紅柿 / 1022人閱讀

摘要:字符的表示法允許采用形式表示一個字符,其中表示字符的碼點。方法,用來將字符的不同表示方法統(tǒng)一為同樣的形式,這稱為正規(guī)化。,默認(rèn)參數(shù),表示標(biāo)準(zhǔn)等價合成,返回多個簡單字符的合成字符。返回布爾值,表示參數(shù)字符串是否在原字符串的頭部。

ECMAScript6/ES6 入門

let和const命令
變量的解構(gòu)賦值

五、字符串的擴(kuò)展

注:這章沒什么可以理解的,看過一遍就行,所以大體上我把有用的一些東西拷過來給大家看下。
1、字符的Unicode表示法
JavaScript 允許采用uxxxx形式表示一個字符,其中xxxx表示字符的 Unicode 碼點。但是,這種表示法只限于碼點在u0000~uFFFF之間的字符。超出這個范圍的字符,必須用兩個雙字節(jié)的形式表示。如果直接在u后面跟上超過0xFFFF的數(shù)值(比如u20BB7),JavaScript 會理解成u20BB+7。由于u20BB是一個不可打印字符,所以只會顯示一個空格,后面跟著一個7。

"uD842uDFB7"
// "?"

"u20BB7"
// " 7"

在ES6中做了處理,只要將碼點放入大括號,就能正確解讀該字符。有了這種表示法之后,JavaScript 共有 6 種方法可以表示一個字符。

"u{20BB7}"
// "?"

"u{41}u{42}u{43}"
// "ABC"

let hello = 123;
hellu{6F} // 123

"u{1F680}" === "uD83DuDE80"
// true
"z" === "z"  // true
"172" === "z" // true
"x7A" === "z" // true
"u007A" === "z" // true
"u{7A}" === "z" // true

2、codePointAt()
對于原來的charAtcharCodeAt,是無法獲取4個字節(jié)的字符串的,charCodeAt方法只能分別返回前兩個字節(jié)和后兩個字節(jié)的值。而有些漢字是需要4個字節(jié)的,比如:漢字“?”(注意,這個字不是“吉祥”的“吉”)的碼點是0x20BB7

var s = "?";

s.length // 2
s.charAt(0) // ""
s.charAt(1) // ""
s.charCodeAt(0) // 55362
s.charCodeAt(1) // 57271

所以在ES6中提供了codePointAt方法,能夠正確返回4個字節(jié)存儲的字符串。

let s = "?a";

s.codePointAt(0) // 134071
s.codePointAt(1) // 57271

s.codePointAt(2) // 97

有的人就要問了,codePointAt方法為啥是3個字符(0,1,2)?首先,JavaScript肯定是將"?a"視作3個字符的,只是ES6方法不同而已,codePointAt(0)返回的是第一字符"?",codePointAt(1)返回的是"?"(共4個字節(jié))的后兩個字節(jié),codePointAt(2)返回的是"a"。也就是說后兩個字節(jié),codePointAt方法的結(jié)果與charCodeAt方法相同。
同時,從上面的例子可以看出,codePointAt方法返回的是碼點的十進(jìn)制值,如果想要十六進(jìn)制的值,可以使用toString方法轉(zhuǎn)換一下。

let s = "?a";

s.codePointAt(0).toString(16) // "20bb7"
s.codePointAt(2).toString(16) // "61"

可能這樣看上去感覺怪怪的,畢竟只有兩個字符,寫的時候還要去注意0,2,其實有更好的解決辦法,利用for...of循環(huán),直接看例子:

let s = "?a";
for (let ch of s) {
  console.log(ch.codePointAt(0).toString(16));
}
// 20bb7
// 61

3、String.fromCodePoint()
String.fromCharCode用于從碼點返回對應(yīng)字符,但是這個方法不能識別 32 位的 UTF-16 字符(Unicode 編號大于0xFFFF)。

String.fromCharCode(0x20BB7)
// "?"

ES6 提供了String.fromCodePoint方法,可以識別大于0xFFFF的字符,彌補(bǔ)了String.fromCharCode方法的不足。在作用上,正好與codePointAt方法相反。

String.fromCodePoint(0x20BB7)
// "?"
String.fromCodePoint(0x78, 0x1f680, 0x79) === "xuD83DuDE80y"
// true

4、字符串的遍歷器接口

for (let codePoint of "foo") {
  console.log(codePoint)
}
// "f"
// "o"
// "o"

for...of循環(huán)遍歷,這個遍歷器最大的優(yōu)點是可以識別大于0xFFFF的碼點,傳統(tǒng)的for循環(huán)無法識別這樣的碼點。
5、at()
同上,charAt不能識別碼點大于0xFFFF的字符。at則可以。

"abc".at(0) // "a"
"?".at(0) // "?"

6、normalize()
normalize()方法,用來將字符的不同表示方法統(tǒng)一為同樣的形式,這稱為 Unicode 正規(guī)化。
許多歐洲語言有語調(diào)符號和重音符號。為了表示它們,Unicode 提供了兩種方法。一種是直接提供帶重音符號的字符,比如ǒ(u01D1)。另一種是提供合成符號(combining character),即原字符與重音符號的合成,兩個字符合成一個字符,比如O(u004F)ˇ(u030C)合成ǒ(u004Fu030C)。

"u01D1"==="u004Fu030C" //false

"u01D1".normalize() === "u004Fu030C".normalize()
// true
normalize方法可以接受一個參數(shù)來指定normalize的方式,參數(shù)的四個可選值如下。

NFC,默認(rèn)參數(shù),表示“標(biāo)準(zhǔn)等價合成”(Normalization Form Canonical Composition),返回多個簡單字符的合成字符。所謂“標(biāo)準(zhǔn)等價”指的是視覺和語義上的等價。
NFD,表示“標(biāo)準(zhǔn)等價分解”(Normalization Form Canonical Decomposition),即在標(biāo)準(zhǔn)等價的前提下,返回合成字符分解的多個簡單字符。
NFKC,表示“兼容等價合成”(Normalization Form Compatibility Composition),返回合成字符。所謂“兼容等價”指的是語義上存在等價,但視覺上不等價,比如“囍”和“喜喜”。(這只是用來舉例,normalize方法不能識別中文。)
NFKD,表示“兼容等價分解”(Normalization Form Compatibility Decomposition),即在兼容等價的前提下,返回合成字符分解的多個簡單字符。

7、includes(), startsWith(), endsWith()
indexOf方法,可以用來確定一個字符串是否包含在另一個字符串中。ES6 又提供了三種新方法。

includes():返回布爾值,表示是否找到了參數(shù)字符串。
startsWith():返回布爾值,表示參數(shù)字符串是否在原字符串的頭部。
endsWith():返回布爾值,表示參數(shù)字符串是否在原字符串的尾部。
let s = "Hello world!";

s.startsWith("Hello") // true
s.endsWith("!") // true
s.includes("o") // true

這三個方法都支持第二個參數(shù),表示開始搜索的位置。

let s = "Hello world!";

s.startsWith("world", 6) // true
s.endsWith("Hello", 5) // true
s.includes("Hello", 6) // false

8、repeat()
repeat方法返回一個新字符串,表示將原字符串重復(fù)n次。參數(shù)如果是小數(shù),會被取整。如果repeat的參數(shù)是負(fù)數(shù)或者Infinity,會報錯。

"x".repeat(3) // "xxx"
"na".repeat(2.9) // "nana"
"na".repeat(0) // ""
"na".repeat(Infinity)
// RangeError
"na".repeat(-1)
// RangeError

但是,如果參數(shù)是 0 到-1 之間的小數(shù),則等同于 0,這是因為會先進(jìn)行取整運算。0 到-1 之間的小數(shù),取整以后等于-0,repeat視同為 0。

"na".repeat(-0.9) // ""

參數(shù)NaN等同于 0。

"na".repeat(NaN) // ""

如果repeat的參數(shù)是字符串,則會先轉(zhuǎn)換成數(shù)字。

"na".repeat("na") // ""
"na".repeat("3") // "nanana"

9、padStart(),padEnd()
如果某個字符串不夠指定長度,會在頭部或尾部補(bǔ)全。padStart()用于頭部補(bǔ)全,padEnd()用于尾部補(bǔ)全。

"x".padStart(5, "ab") // "ababx"
"x".padStart(4, "ab") // "abax"

"x".padEnd(5, "ab") // "xabab"
"x".padEnd(4, "ab") // "xaba"

如果原字符串的長度,等于或大于指定的最小長度,則返回原字符串。

"xxx".padStart(2, "ab") // "xxx"
"xxx".padEnd(2, "ab") // "xxx"

如果省略第二個參數(shù),默認(rèn)使用空格補(bǔ)全長度。

"x".padStart(4) // "   x"
"x".padEnd(4) // "x   "

padStart的常見用途是為數(shù)值補(bǔ)全指定位數(shù)。下面代碼生成 10 位的數(shù)值字符串。

"1".padStart(10, "0") // "0000000001"
"12".padStart(10, "0") // "0000000012"
"123456".padStart(10, "0") // "0000123456"

10、模板字符串
用反引號(`)標(biāo)識,它可以當(dāng)作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量。

// 普通字符串
`In JavaScript "
" is a line-feed.`

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

console.log(`string text line 1
string text line 2`);

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

11、實例:模板編譯

let template = `
    <% for(let i=0; i < data.supplies.length; i++) { %>
  • <%= data.supplies[i] %>
  • <% } %>
`;

上面代碼在模板字符串之中,放置了一個常規(guī)模板。該模板使用<%...%>放置 JavaScript 代碼,使用<%= ... %>輸出 JavaScript 表達(dá)式。
怎么編譯這個模板字符串呢?

一種思路是將其轉(zhuǎn)換為 JavaScript 表達(dá)式字符串。

echo("
    "); for(let i=0; i < data.supplies.length; i++) { echo("
  • "); echo(data.supplies[i]); echo("
  • "); }; echo("
");

這個轉(zhuǎn)換使用正則表達(dá)式就行了。

let evalExpr = /<%=(.+?)%>/g;
let expr = /<%([sS]+?)%>/g;

template = template
  .replace(evalExpr, "`); 
  echo( $1 ); 
  echo(`")
  .replace(expr, "`); 
 $1 
  echo(`");

template = "echo(`" + template + "`);";

然后,將template封裝在一個函數(shù)里面返回,就可以了。

let script =
`(function parse(data){
  let output = "";

  function echo(html){
    output += html;
  }

  ${ template }

  return output;
})`;

return script;

將上面的內(nèi)容拼裝成一個模板編譯函數(shù)compile。

function compile(template){
  const evalExpr = /<%=(.+?)%>/g;
  const expr = /<%([sS]+?)%>/g;

  template = template
    .replace(evalExpr, "`); 
  echo( $1 ); 
  echo(`")
    .replace(expr, "`); 
 $1 
  echo(`");

  template = "echo(`" + template + "`);";

  let script =
  `(function parse(data){
    let output = "";

    function echo(html){
      output += html;
    }

    ${ template }

    return output;
  })`;

  return script;
}

compile函數(shù)的用法如下。

let parse = eval(compile(template));
div.innerHTML = parse({ supplies: [ "broom", "mop", "cleaner" ] });
//   
    //
  • broom
  • //
  • mop
  • //
  • cleaner
  • //

11、String.raw()
String.raw方法,往往用來充當(dāng)模板字符串的處理函數(shù),返回一個斜杠都被轉(zhuǎn)義(即斜杠前面再加一個斜杠)的字符串,對應(yīng)于替換變量后的模板字符串。

String.raw`Hi
${2+3}!`;
// "Hi
5!"

String.raw`Hiu000A!`;
// "Hiu000A!"

如果原字符串的斜杠已經(jīng)轉(zhuǎn)義,那么String.raw不會做任何處理。

String.raw`Hi
`
// "Hi
"

String.raw的代碼基本如下。

String.raw = function (strings, ...values) {
  let output = "";
  let index;
  for (index = 0; index < values.length; index++) {
    output += strings.raw[index] + values[index];
  }

  output += strings.raw[index]
  return output;
}

String.raw方法可以作為處理模板字符串的基本方法,它會將所有變量替換,而且對斜杠進(jìn)行轉(zhuǎn)義,方便下一步作為字符串來使用。

String.raw方法也可以作為正常的函數(shù)使用。這時,它的第一個參數(shù),應(yīng)該是一個具有raw屬性的對象,且raw屬性的值應(yīng)該是一個數(shù)組。

String.raw({ raw: "test" }, 0, 1, 2);
// "t0e1s2t"

// 等同于

String.raw({ raw: ["t","e","s","t"] }, 0, 1, 2);

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/92248.html

相關(guān)文章

  • ES6學(xué)習(xí)摘要(01)(新人學(xué)習(xí)

    摘要:入門一前言由于最近本人在學(xué)習(xí),做一些筆記能夠更好的熟悉,就趁此機(jī)會來寫一篇關(guān)于的新人學(xué)習(xí)摘要吧。的作用域與命令相同只在聲明所在的塊級作用域內(nèi)有效。塊級作用域新增方式和實際上為新增了塊級作用域。同時,函數(shù)聲明還會提升到所在的塊級作用域的頭部。 ECMAScript6/ES6 入門 一、前言 由于最近本人在學(xué)習(xí)ES6,做一些筆記能夠更好的熟悉,就趁此機(jī)會來寫一篇關(guān)于ES6的新人學(xué)習(xí)摘要吧。...

    dmlllll 評論0 收藏0
  • ES6學(xué)習(xí)摘要(02)(新人學(xué)習(xí)

    摘要:默認(rèn)值同時,對象解構(gòu)賦值也允許設(shè)置默認(rèn)值,默認(rèn)值生效的判斷條件同數(shù)組,只有在對應(yīng)值嚴(yán)格等于時會生效。報錯如果要將一個已經(jīng)聲明的變量用于解構(gòu)賦值,必須非常小心。的規(guī)則是,只要有可能導(dǎo)致解構(gòu)的歧義,就不得使用圓括號。 ECMAScript6/ES6 入門 let和const命令 四、變量的解構(gòu)賦值 在ES6之前,數(shù)組和對象屬性賦值只能直接指定固定值,ES6 允許按照一定模式,從數(shù)組和對象中...

    Jonathan Shieber 評論0 收藏0
  • 2017前端現(xiàn)狀--答題救不了前端新人

    摘要:眾所周知,前端近幾年鬧了一場革命。這些問題反應(yīng)了什么現(xiàn)象確實前端很火,引來了一批批新人。前端小白們?nèi)缁鹑巛钡膶W(xué)習(xí)著現(xiàn)在前端流行的新技術(shù)棧。寫在最后所以啊,在目睹了很多白癡問題后,我終于發(fā)出了一聲吶喊,答題救不了前端新人。 眾所周知,前端近幾年鬧了一場革命。前端在編程領(lǐng)域也掀起了學(xué)習(xí)潮。至少在中國,從2013年下半年至今,在搜索指數(shù)上,有著爆炸式的增長。可以看下數(shù)據(jù):百度指數(shù),Googl...

    jone5679 評論0 收藏0
  • 2017前端現(xiàn)狀--答題救不了前端新人

    摘要:眾所周知,前端近幾年鬧了一場革命。這些問題反應(yīng)了什么現(xiàn)象確實前端很火,引來了一批批新人。前端小白們?nèi)缁鹑巛钡膶W(xué)習(xí)著現(xiàn)在前端流行的新技術(shù)棧。寫在最后所以啊,在目睹了很多白癡問題后,我終于發(fā)出了一聲吶喊,答題救不了前端新人。 眾所周知,前端近幾年鬧了一場革命。前端在編程領(lǐng)域也掀起了學(xué)習(xí)潮。至少在中國,從2013年下半年至今,在搜索指數(shù)上,有著爆炸式的增長??梢钥聪聰?shù)據(jù):百度指數(shù),Googl...

    alogy 評論0 收藏0
  • 剛進(jìn)入軟件測試行業(yè)的新人,這些寶貴經(jīng)驗要收好~

    摘要:軟件測試從宏觀上可以分為功能測試性能測試安全性測試三個方面,如果能將三者結(jié)合起來就說明已經(jīng)將這個崗位做的十分好了。 恍然間,發(fā)現(xiàn)自己已經(jīng)在這個行業(yè)五年之久,回顧過往,思緒良多,一路走來,或多或少都經(jīng)歷過一些坎坷,也碰到過不少大大小小的困難。在此就不多加敘述了。 本篇文章主要想寫給剛?cè)腴T的測...

    馬永翠 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<