傳統(tǒng)的indexOf可以用來確定一個(gè)字符串是否包含在另一個(gè)字符串中。ES6 又提供了三種新方法。
includes():返回布爾值,表示是否找到了參數(shù)字符串。
startsWith():返回布爾值,表示參數(shù)字符串是否在原字符串的頭部。
endsWith():返回布爾值,表示參數(shù)字符串是否在原字符串的尾部。
let s = 'Hello world!';
s.startsWith('world', 6) // true
s.endsWith('Hello', 5) // true
s.includes('Hello', 6) // false
上面代碼表示,使用第二個(gè)參數(shù)n時(shí),endsWith的行為與其他兩個(gè)方法有所不同。它針對前n個(gè)字符,而其他兩個(gè)方法針對從第n個(gè)位置直到字符串結(jié)束。
repeat方法返回一個(gè)新字符串,表示將原字符串重復(fù)n次。
'x'.repeat(3) // "xxx"
'hello'.repeat(2) // "hellohello"
'na'.repeat(0) // ""
參數(shù)如果是小數(shù),會(huì)被取整。如下:
'na'.repeat(2.9) // "nana"
padStart(),padEnd() ES2017 引入了字符串補(bǔ)全長度的功能。如果某個(gè)字符串不夠指定長度,會(huì)在頭部或尾部補(bǔ)全。padStart()用于頭部補(bǔ)全,padEnd()用于尾部補(bǔ)全。
去除空格
ES2019 對字符串實(shí)例新增了
trimStart()和trimEnd()這兩個(gè)方法。它們的行為與trim()一致,trimStart()消除字符串頭部的空格,trimEnd()消除尾部的空格。它們返回的都是新字符串,不會(huì)修改原始字符串。
const s = ' abc ';
s.trim() // "abc"
s.trimStart() // "abc "
s.trimEnd() // " abc"
歷史上,字符串的實(shí)例方法replace()只能替換第一個(gè)匹配。ES2021 引入了replaceAll()方法,可以一次性替換所有匹配。
它的用法與replace()相同,返回一個(gè)新字符串,不會(huì)改變原字符串。
第一個(gè)參數(shù)可以是一個(gè)字符串,也可以是一個(gè)全局的正則表達(dá)式(帶有g(shù)修飾符)。
如果是一個(gè)不帶有g(shù)修飾符的正則表達(dá)式,replaceAll()會(huì)報(bào)錯(cuò)。這一點(diǎn)跟replace()不同。