es6 字符串String的擴展(實例講解)
新特性:模板字符串
傳統(tǒng)字符串
let name = "Jacky"; let occupation = "doctor"; //傳統(tǒng)字符串拼接 let str = "He is "+ name +",he is a "+ occupation;
es6簡潔的字符串拼接
let name = "Jacky";
let occupation = "doctor";
//模板字符串拼接
let str = `He is ${name},he is a ${occupation}`;
對比兩段拼接的代碼,模板字符串使得我們不再需要反復(fù)使用雙引號(或者單引號)了;而是改用反引號標(biāo)識符(`),插入變量的時候也不需要再使用加號(+)了,而是把變量放入${ }即可。
使用時要注意
1、可以定義多行字符串
傳統(tǒng)的多行字符串寫法:
let str = "write once ," + "run anywhere";
模板字符串的寫法:
let str = `write once , run anywhere`;
直接換行即可,但是要注意的是:所有的空格和所進都會被保留在輸出中。如果控制臺輸出字符串str的話,代碼上換了行,控制臺輸出的時候也會換行。
2、${ }中可以放任意的javascript表達式
${ }中可以是運算表達式
var a = 1;
var b = 2;
var str = `the result is ${a+b}`;
//進行加法運算 結(jié)果:the result is 3
${ }中可以是對象的屬性
var obj = {"a":1,"b":2};
var str = `the result is ${obj.a+obj.b}`;
//對象obj的屬性
//結(jié)果:the result is 3.
${ }中可以是函數(shù)的調(diào)用
function fn() {
return 3;
}
var str = `the result is ${ fn() }`;
//函數(shù)fn的調(diào)用,結(jié)果:the result is 3
標(biāo)簽?zāi)0?/strong>
這里的模板指的是上面講的字符串模板,用反引號定義的字符串;而標(biāo)簽,則指的是一個函數(shù),一個專門處理模板字符串的函數(shù)。
var name = "張三";
var height = 1.8;
tagFn`他叫${name},身高${height}米。`;
//標(biāo)簽+模板字符串
//定義一個函數(shù),作為標(biāo)簽
function tagFn(arr,v1,v2){
console.log(arr);
//結(jié)果:[ "他叫",",身高","米。" ]
console.log(v1);
//結(jié)果:張三
console.log(v2);
//結(jié)果:1.8
}
以上代碼有兩處要仔細(xì)講解的,首先是tagFn函數(shù),是我們自定義的一個函數(shù),它有三個參數(shù)分別是arr,v1,v2。函數(shù)tagFn的調(diào)用方式跟以往的不太一樣,以往我們使用括號( )表示函數(shù)調(diào)用執(zhí)行,這一次我們在函數(shù)名后面直接加上一個模板字符串,如下面的代碼:
tagFn`他叫${name},身高${height}米。`;
這樣就是標(biāo)簽?zāi)0?,你可以理解為?biāo)簽函數(shù)+模板字符串,這是一種新的語法規(guī)范。
接下來我們繼續(xù)看函數(shù)的3個參數(shù),從代碼的打印結(jié)果我們看到它們運行后對應(yīng)的結(jié)果,arr的值是一個數(shù)組:[ "他叫" , ",身高" , "米。" ],而v1的值是變量name的值:“張三”,v2的值是變量height的值:1.8。
你是否看出規(guī)律了:第一個參數(shù)arr是數(shù)組類型,它是內(nèi)容是模板字符串中除了${ }以外的其他字符,按順序組成了數(shù)組的內(nèi)容,所以arr的值是[ "他叫", ",身高" , "米。" ];第2,3個參數(shù)則是模板字符串中對應(yīng)次序的變量name和height的值。
標(biāo)簽?zāi)0迨荅S6給我們帶來的一種新語法,它常用來實現(xiàn)過濾用戶的非法輸入和多語言轉(zhuǎn)換,這里不展開講解。因為一旦我們掌握了標(biāo)簽?zāi)0宓挠梅ê?,以后就可以好好利用它的這個特性,再根據(jù)自己的需求要來實現(xiàn)各種功能了。
ES6新的String函數(shù)
repeat( )函數(shù):將目標(biāo)字符串重復(fù)N次,返回一個新的字符串,不影響目標(biāo)字符串。
var name1 = "王漢炎"; //目標(biāo)字符串 var name2 = name1.repeat(3); //變量name1被重復(fù)三次; console.log(name1); //結(jié)果:王漢炎 console.log(name2); //結(jié)果:王漢炎王漢炎王漢炎
includes( )函數(shù):判斷字符串中是否含有指定的子字符串,返回true表示含有和false表示未含有。第二個參數(shù)選填,表示開始搜索的位置。
var name = "王漢炎";//目標(biāo)字符串
name.includes('炎');
//true, 含有
name.includes('web');
//false, 不含有
name.includes('王',1);
//false, 從第2個字符開始搜索, 不含有
傳統(tǒng)的做法我們可以借助indexOf( )函數(shù)來實現(xiàn),如果含有指定的字符串,indexOf( )函數(shù)就會子字符串首次出現(xiàn)的位置,不含有,則返回-1。我們通過返回值是否為-1來判斷字符串中是否含有指定的子字符串,但是,我們現(xiàn)在可以用includes( )函數(shù)代替indexOf( )函數(shù),因為它的返回值更直觀(true或false),況且我們并不關(guān)心子字符串出現(xiàn)的位置。
startsWith( )函數(shù):判斷指定的子字符串是否出現(xiàn)在目標(biāo)字符串的開頭位置,第二個參數(shù)選填,表示開始搜索的位置。
var name = "王漢炎"; //目標(biāo)字符串
name.startsWith('王');
//true,出現(xiàn)在開頭位置
name.startsWith('漢');
//false,不是在開頭位置
name.startsWith('漢',1);
//true,從第2個字符開始
endsWith( )函數(shù):判斷子字符串是否出現(xiàn)在目標(biāo)字符串的尾部位置,第二個參數(shù)選填,表示針對前N個字符。
var name = "我就是王漢炎";//目標(biāo)字符串
name.endsWith('我');
//false,不在尾部位置
name.endsWith('炎');
//true,在尾部位置
name.endsWith('炎',5);
//false,只針對前5個字符
name.endsWith('炎',6);
//true,針對前6個字符
javascript中,一個字符固定為2個字節(jié),對于那些需要4個字節(jié)存儲的字符,javascript會認(rèn)為它是兩個字符,此時它的字符長度length為2。如字符:"𠮷",就是一個需要4個字節(jié)存儲,length為2的字符。這會有什么問題呢?對于4字節(jié)的字符, javascript無法正確讀取字符,我們來試試看。
var str1 = "前端"; var str2 = "𠮷"; str1.length; //length為2 str2.length; //length為2 str1.charAt(0); //前 str1.charAt(1); //端 str2.charAt(0); //'�' str2.charAt(1); //'�'
可以看到,str1和str2的長度length都是2,因為字符:"𠮷"是一個4字節(jié)的字符,使用charAt函數(shù)(charAt() 方法可返回指定位置的字符)能正確讀取字符串str1的字符,但無法正確讀取4個字節(jié)的字符,此時返回結(jié)果出現(xiàn)了亂碼。
但是,如果我們使用ES6給我們提供的codePointAt( )函數(shù),就可以處理這種4個字節(jié)的字符了,我們來看看怎么使用
var str = "𠮷"; str.codePointAt(); //結(jié)果:134071
對于這個長度length為2字符:"𠮷",codePointAt( )方法可以正確地識別出它是個4個字節(jié)的字符,并且能正確地返回它的碼點的十進制數(shù):134071,這個數(shù)字抓換成16進制就是20bb7,對應(yīng)的Unicode編碼則是\u20bb7。
String.fromCodePoint( )函數(shù):函數(shù)的參數(shù)是一個字符對應(yīng)的碼點,返回的結(jié)果就是對應(yīng)的字符,哪怕這個字符是一個4字節(jié)的字符,也能正確實現(xiàn)。
正好可以利用上面得到的10進制數(shù)字134071反推一下。
String.fromCodePoint(134071); //結(jié)果:"𠮷"
String.raw( )函數(shù);看函數(shù)名raw是未加工的的意思,正如這個函數(shù)的作用一樣:返回字符串最原始的樣貌,即使字符串中含有轉(zhuǎn)義符,它都視而不見,直接輸出。
console.log(`hello\nworld`); //輸出:hello world console.log(String.raw`hello\nwolrd`); //輸出:hello\nwolrd
總結(jié):ES6給字符串帶來了很多實用性的擴展:模板字符串,標(biāo)簽?zāi)0?,repeat函數(shù)、includes函數(shù),startsWith函數(shù),endsWith函數(shù),codePointAt函數(shù),String.fromCodePoint函數(shù),String.raw函數(shù)。
以上這篇es6 字符串String的擴展(實例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序網(wǎng)絡(luò)請求模塊封裝的具體實現(xiàn)
大家做小程序項目的時候肯定會遇到數(shù)據(jù)對接需求,下面這篇文章主要給大家介紹了關(guān)于微信小程序網(wǎng)絡(luò)請求模塊封裝的具體實現(xiàn),文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03
js實現(xiàn)七夕表白彈幕效果 jQuery實現(xiàn)彈幕技術(shù)
這篇文章主要介紹了js實現(xiàn)七夕表白彈幕效果,jQuery實現(xiàn)彈幕技術(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08
用函數(shù)式編程技術(shù)編寫優(yōu)美的 JavaScript_ibm
函數(shù)式編程語言在學(xué)術(shù)領(lǐng)域已經(jīng)存在相當(dāng)長一段時間了,但是從歷史上看,它們沒有豐富的工具和庫可供使用。隨著 .NET 平臺上的 Haskell 的出現(xiàn),函數(shù)式編程變得更加流行。一些傳統(tǒng)的編程語言,例如 C++ 和 JavaScript,引入了由函數(shù)式編程提供的一些構(gòu)造和特性。在許多情況下,JavaScript 的重復(fù)代碼導(dǎo)致了一些拙劣的編碼。如果使用函數(shù)式編程,就可以避免這些問題。此外,可以利用函數(shù)式編程風(fēng)格編寫更加優(yōu)美的回調(diào)。2008-05-05
微信小程序通過websocket實時語音識別的實現(xiàn)代碼
這篇文章主要介紹了微信小程序通過websocket實時語音識別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
微信小程序 導(dǎo)入圖標(biāo)實現(xiàn)過程詳解
這篇文章主要介紹了微信小程序 導(dǎo)入圖標(biāo)實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10

