婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > 當(dāng)ES6遇上字符串和正則表達(dá)式

當(dāng)ES6遇上字符串和正則表達(dá)式

熱門標(biāo)簽:呼叫系統(tǒng)外呼只能兩次 西藏智能外呼系統(tǒng)代理商 梅縣地圖標(biāo)注 400電話辦理電話辦理 甘肅醫(yī)療外呼系統(tǒng)排名 貴港公司如何申請(qǐng)400電話 ai電話機(jī)器人搭建 外呼系統(tǒng)無呼出路由是什么原因 地圖標(biāo)注教學(xué)點(diǎn)

字符串是一種重要的數(shù)據(jù)類型,而正則表達(dá)式則是賦予了編程人員更多操作字符串的能力。ES6的創(chuàng)作者為字符串和正則表達(dá)式添加了許多的新功能。下面玲瓏將來進(jìn)行一個(gè)全面的總結(jié)。

字符串和正則兩個(gè)部分各兩節(jié),全文閱讀時(shí)間大約10分鐘

字符串

1.更好的Unicode支持

Unicode是一個(gè)字符集。將全世界所有的字符包含在一個(gè)集合里,計(jì)算機(jī)只要支持這一個(gè)字符集,就能顯示所有的字符,再也不會(huì)有亂碼了。

在es6出現(xiàn)之前,js字符串一直基于16位字符編碼進(jìn)行構(gòu)建。每16位序列是一個(gè)編碼單元,代表一個(gè)字符,Unicode0引入擴(kuò)展字符集,16位字符編碼將不再包含任何字符。編碼規(guī)則也因此變更。

對(duì)于UTF-16來說,碼位可以有多個(gè)編碼單元表示,是表示不是組成。

對(duì)于UTF-16前2^16個(gè)碼位都是16位的編碼單元表示,這個(gè)范圍被稱作基本多文種平面BMP,當(dāng)超過時(shí),引入代理對(duì),規(guī)定用兩個(gè)16位編碼單元表示一個(gè)碼位,即32位輔助平面字符。一個(gè)32位代理對(duì)表示字符長(zhǎng)度為1,但是length屬性值為2.

如果想進(jìn)一步了解他可以參考阮一峰的一片日志: www.ruanyifeng.com/blog/2014/1… 日志里面說到的碼點(diǎn)就是碼位

1.1codePointAt(0)方法

在es6之前,charCodeAt()方法返回字符每個(gè)16位編碼單元對(duì)應(yīng)的數(shù)值,再在es6中新增了codePointAt方法,codePointAt(0)返回的是位置0處的碼點(diǎn)或者說是位置0處的碼位,包含多個(gè)編碼單元>16進(jìn)制上限FFFF,charCodeAt(0)方法返回的是位置0的第一個(gè)編碼單元.

因此可以用此方法判斷一個(gè)字符占用編碼單元的數(shù)量

function is32Bit(c) {
  
  return c.codePointAt(0) > 0xFFFF;
}
console.log(is32Bit("吉利")); //true
console.log(is32Bit("a"));  //false

1.2 String.fromCodePoint()方法

codePointAt()方法在字符串中檢索一個(gè)字符串的碼位,也可以使用String.fromCodePoint()方法根據(jù)指定的碼位生成一個(gè)字

console.log(String.fromCodePoint(134071));   //吉

1.3normalize()方法

在比較字符或者進(jìn)行排序的時(shí)候,可能出現(xiàn)等價(jià)的情況,然而等價(jià)卻存在兩種情況

  • 規(guī)范的等效是無論從哪個(gè)角度來看,兩個(gè)序列的碼位都是沒有區(qū)別的
  • 兼容的碼位序列看起來不同,但是在特定的情況下可以交換使用。 但是在嚴(yán)格模式下不是等效的,除非通過某些方法把這種等效關(guān)系標(biāo)準(zhǔn)化

normalize()方法提供Unicode的標(biāo)準(zhǔn)化形式,,這個(gè)方法可以接受一個(gè)可選的字符串參數(shù)。Unicode標(biāo)準(zhǔn)化形式有四種

以標(biāo)準(zhǔn)等價(jià)方式分解,然后以標(biāo)準(zhǔn)等價(jià)方式重組(“NFC”),默認(rèn)值選項(xiàng)

  • 以標(biāo)準(zhǔn)等價(jià)方式分解(“NFD”)
  • 以兼容等價(jià)方式分解(“NFKC”)
  • 以兼容方式分解,然后以標(biāo)準(zhǔn)等價(jià)方式重組

1.4 正則表達(dá)式u修飾符

正則表達(dá)式后添加u修飾符會(huì)將編碼單元模式切換成字符模式,這個(gè)時(shí)候的代理對(duì)不會(huì)被視為兩個(gè)字符。

但是length這個(gè)屬性返回的仍然是字符串編碼單元的數(shù)量,而不是碼位的數(shù)量。但是也可以通過帶u修飾符的正則表達(dá)式來解決這個(gè)問題。

function codePointerLength(text) {
  let result = text.match(/[\s\S]/gu);
  return result ? result.length:0;
}
console.log(codePointerLength("吉abc")); //4

檢測(cè)是否支持u修飾符

u修飾符在不兼容ES6的JavaScript引擎中使用會(huì)導(dǎo)致語法錯(cuò)誤,可以通過以下函數(shù)檢測(cè)是否支持。

function hasRegExpU() {
  try{
    var pattern = new Regexp(".","u");
    return ture;
  }catch (ex) {
    return false;
  }
}

2.其他字符串的變更

2.1字符串中的字串識(shí)別

開發(fā)者們用indexOf()方法在一段字符串中檢測(cè)另一段子字符串。在es6中提供3個(gè)方法達(dá)到類似的效果

  • startWith()方法,在字符串起始部分檢測(cè)指定文本返回true,否則返回false。
  • incledes()方法,如果在字符串中檢測(cè)到指定文本返回true,否則返回false。
  • endWith()方法,顧名思義在末尾檢測(cè),用法與上面一致。

上面三個(gè)方法接受兩個(gè)參數(shù),第1個(gè)參數(shù)是指定要搜索的文本是一個(gè)字符。第2個(gè)是開始搜索位置的索引值是一個(gè)數(shù)字。不指定第二個(gè)參數(shù)endwith一般從字符串末尾處開始匹配。示范如下

let mes = "hello world";
console.log(mes.startWith("hello"));
console.log(mes.endWith("!"));
console.log(mes.includes("o"));
console.log(mes.startWith("o"));
console.log(mes.endWith("d!"));
console.log(mes.includes("x"));
console.log(mes.startWith("o",4));
console.log(mes.endWith("o",8));
console.log(mes.includes("o",8));
//9個(gè)結(jié)果依次為:true true true  false true false  true true false
console.log(mes.endWith("o",8));會(huì)從第7位第二個(gè)o開始匹配。索引值-要搜索文本的長(zhǎng)度=8-1

2.2 repeat()方法

es6為字符串新增加的repeat()方法,接受一個(gè)number類型的參數(shù),返回重復(fù)該次數(shù)的一個(gè)新字符串。

console.log(x.repeat(3)); //"xxx"

我是2條分割線,嘎嘎嘎

正則表達(dá)式

1.其他正則表達(dá)式的變更

1.1正則表達(dá)式y(tǒng)修飾符

y修飾符粘滯正則表達(dá)式,從正則表達(dá)式的lastIndex屬性開始進(jìn)行。如果指定位置沒有匹配成功那么將停止匹配并返回結(jié)果。

let text = 'hello1 hello2 hello3';
let patt = /hello\d\s?/,
  result = patt.exec(text);
let gPatt = /helllo\d\s?/g,
  gResult = gPatt.exec(text);
let yPatt = /hello\d\s?/y,
  yResult = yPatt.exec(text);
console.log(resut[0]);  //"hello1 "
console.log(gResut[0]);  //"hello1 "
console.log(yResut[0]);  //"hello1 "
patt.lastIndex = 1;
gPatt.lastIndex = 1;
yPatt.lastIndex = 1;
result = patt.exec(text);
gResult = gPatt.exec(text);
yResult = yPatt.exec(text);
console.log(resut[0]);  //"hello1 "
console.log(gResut[0]);  //"hello2 "
console.log(yResut[0]);  //拋出錯(cuò)誤

這里三個(gè)正則表達(dá)式中,第一個(gè)沒有修飾符,第二個(gè)全局修飾符g,第三個(gè)用了y修飾符。

第一次匹配的時(shí)候是從h字符開始匹配。當(dāng)lastIndex = 1;之后,對(duì)于沒有修飾符的表達(dá)式自動(dòng)忽略這個(gè)變化,結(jié)果還是hello1 ,g修飾符會(huì)從e字符開始匹配,輸出hello2 ,yResul會(huì)從e字符開始匹配,ello h與之不等,最后結(jié)果為null,所以會(huì)拋出錯(cuò)誤。

當(dāng)執(zhí)行y修飾符之后,會(huì)把上一次匹配最后的一個(gè)字符的后一位索引值保存在lastIndex中去,如果執(zhí)行y修飾符匹配結(jié)果為空那么lastIndex值會(huì)被重置為0,g修飾符與此相同。

只有調(diào)用正則表達(dá)式對(duì)象的exec()和test()這些方法時(shí)才會(huì)設(shè)計(jì)lastIndex屬性,如調(diào)用字符串的方法natch()就不會(huì)觸發(fā)粘滯行為。

檢測(cè)y修飾符是否存在可以用sticky屬性,如果js引擎支持粘滯修飾符,則stickey屬性值為true,否則為false

let patt = /hello\d/y;
console.log(patt.sticky);

1.2正則表達(dá)式的復(fù)制

在es5中,可以給正則表達(dá)式的構(gòu)造函數(shù)傳遞正則表達(dá)式作為參數(shù)來復(fù)制這個(gè)正則表達(dá)式。但事實(shí)第一個(gè)參數(shù)為正則表達(dá)式的時(shí)候不能用第二個(gè)參數(shù),es6中修改了這個(gè)行為,第二個(gè)參數(shù)可以是修飾符。

let re1 = /ab/i;
let re2 = new RegExp(re1,"g");
console.log(re1.toString()); // "/ab/i"
console.log(re2.toString()); // "/ab/g"

1.3flags屬性

es6新增的flags屬性會(huì)返回所有應(yīng)用于當(dāng)前正則表達(dá)式的修飾符

let re = /ab/g;
console.log(re.source);  //"ab"
console.log(re.flags);  //"g"

2.模板字面量

2.1基礎(chǔ)語法

一句話概括,用反撇號(hào)(`)代替了雙引號(hào),單引號(hào)。

如果想在字符串中用反撇號(hào),就用\轉(zhuǎn)義即可。如

let message = `\`hello\`!`;
console.log(message);

結(jié)果是 hello!

2.2簡(jiǎn)化的多行字符串

在es6之前,通過數(shù)組或字符串拼接的方法來創(chuàng)建多行字符串,es6中只需要在代碼中直接換行,換行也改變length屬性值。同時(shí)再反撇號(hào)中所有的空格符都屬于字符串的一部分。

let message = `Multiline
string`;
console.log(message);
console.log(message.length);  //16=6+9+1

2.3 字符串占位符

在一個(gè)模板字面量中,你可以把任何合法的JavaScript表達(dá)式嵌入到占位符中并將其作為字符串的一部分輸出到結(jié)果中。

占位符通常由${}組成,中間可包含任何JavaScript表達(dá)式。模板字面量本身也是JavaScript表達(dá)式,因此在一個(gè)模板字面量里面可以嵌入另外一個(gè)模板字面量。

let name = "sarah";
let message = `my${`name is${name}.`}`;
console.log(message);//my name is sarah.

message是一個(gè)模板字面量,里面又包含了name is${name}.這個(gè)模板字面量。

總結(jié)

以上所述是小編給大家介紹的當(dāng)ES6遇上字符串和正則表達(dá)式,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!

您可能感興趣的文章:
  • ES6學(xué)習(xí)筆記之正則表達(dá)式和字符串正則方法分析
  • ES6(ECMAScript 6)新特性之模板字符串用法分析
  • ES6正則表達(dá)式的一些新功能總結(jié)

標(biāo)簽:哈密 湖州 常州 本溪 海口 泰安 大興安嶺 涼山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《當(dāng)ES6遇上字符串和正則表達(dá)式》,本文關(guān)鍵詞  當(dāng),ES6,遇上,字符串,和,正則,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《當(dāng)ES6遇上字符串和正則表達(dá)式》相關(guān)的同類信息!
  • 本頁收集關(guān)于當(dāng)ES6遇上字符串和正則表達(dá)式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲国产成人av好男人在线观看| 成人午夜av电影| 国产精品久久久久影院| 中文字幕亚洲不卡| 国产不卡在线一区| 欧美亚洲丝袜传媒另类| 日韩无一区二区| 91麻豆国产在线观看| 欧美肥妇毛茸茸| 欧美国产精品v| 亚洲男人的天堂在线观看| 日本精品一区二区三区四区的功能| 欧美日韩国产首页| 欧美v国产在线一区二区三区| 精品在线你懂的| 91看片淫黄大片一级在线观看| 欧美久久久久久久久| 麻豆免费看一区二区三区| 欧美疯狂做受xxxx富婆| 国产亚洲欧美激情| 99re这里只有精品6| 日韩欧美国产综合在线一区二区三区| 中文字幕第一区综合| 中文字幕亚洲欧美在线不卡| 成a人片亚洲日本久久| 色综合视频在线观看| 欧美一级理论性理论a| 中文字幕第一页久久| 欧美一三区三区四区免费在线看 | 91久久人澡人人添人人爽欧美| 欧美系列一区二区| 欧美激情综合在线| 7777女厕盗摄久久久| 亚洲最色的网站| 97超碰欧美中文字幕| 亚洲精品在线观看视频| 日欧美一区二区| 精品成人在线观看| 日韩国产高清影视| 欧美午夜寂寞影院| 一区二区三区四区精品在线视频| 欧美成人激情免费网| 亚洲电影你懂得| 91国偷自产一区二区三区成为亚洲经典| 麻豆久久一区二区| 欧美成人伊人久久综合网| 亚洲摸摸操操av| 成人av综合一区| 日韩成人免费在线| 欧美日韩在线播放三区四区| 一区二区三区高清不卡| 久久久久亚洲综合| 国内不卡的二区三区中文字幕| 欧美性xxxxxxxx| 综合久久久久久| 91精品婷婷国产综合久久| 亚洲成人av一区二区三区| 日本高清成人免费播放| 亚洲国产激情av| 91精品国产欧美日韩| 一区二区三区四区激情| 91九色最新地址| 7777精品伊人久久久大香线蕉的| 成人免费黄色在线| 日韩理论片中文av| 欧美老肥妇做.爰bbww| 国产校园另类小说区| 欧美精品亚洲二区| 久久99国内精品| 国产精品久久精品日日| 国产精品色噜噜| 欧美久久久久久蜜桃| 国内精品写真在线观看| 亚洲欧洲精品一区二区三区| 经典一区二区三区| 国产精品久久国产精麻豆99网站| 欧美视频在线观看一区二区| 欧美日韩一区精品| 成人一级片在线观看| 亚洲国产成人av网| 亚洲高清免费观看高清完整版在线观看 | 91精品国产日韩91久久久久久| 在线免费观看日韩欧美| 久久精品国产色蜜蜜麻豆| 久久久久久电影| 天天综合网天天综合色| xnxx国产精品| 色天使久久综合网天天| 亚洲成人精品一区二区| 蜜臀久久久久久久| 中文字幕第一区二区| 国产精一品亚洲二区在线视频| 国产一区在线视频| 婷婷久久综合九色国产成人| 国产精品盗摄一区二区三区| 天天综合色天天综合色h| 亚洲欧美日韩中文字幕一区二区三区| 精品日韩在线观看| 亚洲色图色小说| 综合久久给合久久狠狠狠97色| 日韩三级高清在线| 亚洲色欲色欲www| 国产精品另类一区| 国产亚洲精品bt天堂精选| 午夜精品久久久久久久久久久| 亚洲视频一区在线观看| 久久久久久久精| 欧美三级日韩三级国产三级| 中文字幕免费观看一区| 久久综合五月天婷婷伊人| 日韩欧美成人一区二区| 亚洲黄一区二区三区| 国产精品天美传媒| 国产亚洲精品7777| 日本美女一区二区三区视频| 奇米在线7777在线精品| 日av在线不卡| 欧美日韩中文字幕一区二区| 国产精品久久久久久久午夜片 | 久久久精品国产免大香伊| 日本一区二区免费在线观看视频 | 亚洲成va人在线观看| 日韩美女啊v在线免费观看| 欧美精品一区二区三区视频| 香蕉加勒比综合久久| 婷婷六月综合亚洲| 成人免费在线视频| 成人午夜精品在线| 99久久综合色| 色综合中文字幕国产| 中文字幕乱码久久午夜不卡 | 国产精品福利av| 国产日本欧洲亚洲| 欧美在线免费观看视频| 久久国产欧美日韩精品| 99久久国产综合精品色伊| 精品少妇一区二区三区视频免付费 | 亚洲综合激情小说| 亚洲成人在线免费| 奇米综合一区二区三区精品视频 | 理论电影国产精品| 欧美精品自拍偷拍| 亚洲www啪成人一区二区麻豆 | 精品国产精品一区二区夜夜嗨| 亚洲一区二区四区蜜桃| 色中色一区二区| 亚洲特黄一级片| 91首页免费视频| 一区二区三区不卡视频| 欧美日韩亚洲综合一区| 蜜乳av一区二区三区| 91精品国产色综合久久| 狠狠色丁香九九婷婷综合五月| 91精品国产手机| 一本一本久久a久久精品综合麻豆| 久久精品999| 日韩欧美国产系列| 国产麻豆精品久久一二三| 欧美精品三级日韩久久| 蜜臀av国产精品久久久久| 国产精品一区二区三区99| 精品久久久久久久一区二区蜜臀| 国产一区二区三区四区五区美女| 国产精品视频你懂的| 色www精品视频在线观看| 天天综合网 天天综合色| 久久伊99综合婷婷久久伊| 国产乱子伦一区二区三区国色天香 | 欧美精品 国产精品| 男女性色大片免费观看一区二区| 在线观看免费视频综合| 欧美国产日本韩| 日本韩国精品在线| 欧美精品一区二区三区一线天视频 | 在线不卡一区二区| 国产综合成人久久大片91| 国产精品丝袜久久久久久app| 欧美日韩一区久久| 欧美在线观看一区二区| 国产欧美一区二区在线| 欧美视频精品在线观看| 中文字幕 久热精品 视频在线| 日韩电影在线免费| 欧美成人性战久久| 午夜精品一区在线观看| 91丨九色丨尤物| 中文字幕av一区二区三区高| 国产剧情在线观看一区二区| 久久久久久麻豆| 免费久久99精品国产| 日韩精品资源二区在线| 狠狠色狠狠色合久久伊人| 亚洲激情一二三区| 国产欧美精品一区二区三区四区 | 一区二区三区小说| 日韩精品一区二区三区在线观看 | 国产精品无码永久免费888| 日本欧美肥老太交大片| 日韩丝袜情趣美女图片| 日本久久电影网|