欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解JS截取字符串的三個(gè)方法substring,substr,slice

 更新時(shí)間:2022年03月17日 09:32:49   作者:前端偵探  
js中有三個(gè)截取字符的方法,分別是substring()、substr()、slice(),平時(shí)我們可能都用到過(guò),但總是會(huì)對(duì)這些方法有點(diǎn)混淆。本文將詳細(xì)介紹一下這三者的區(qū)別,需要的可以參考一下

js中有三個(gè)截取字符的方法,分別是substring()、substr()、slice(),平時(shí)我們可能都用到過(guò),但總是會(huì)對(duì)這些方法有點(diǎn)混淆,特別是substring()和substr(),連方法名都差不多,下面就具體來(lái)看一下區(qū)別。

相同點(diǎn)

這三個(gè)方法都可以對(duì)字符串進(jìn)行截取,并且返回一個(gè)新的字符串,也就是不會(huì)對(duì)原字符串進(jìn)行修改 。

這里 > 表示控制臺(tái)輸入,< 表示控制臺(tái)輸出,下同:

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr(1,5)
< "12345"
> a
< "0123456789"  //沒(méi)有發(fā)生改變

不同點(diǎn)

這三個(gè)方法的不同之處在于參數(shù)不同。

substring

substring() 方法用于提取字符串中介于兩個(gè)指定下標(biāo)之間的字符。

語(yǔ)法

string.substring(start,stop)

參數(shù)

參數(shù)描述
? ?start??必需。一個(gè) 非負(fù)的整數(shù) ,規(guī)定要提取的子串的第一個(gè)字符在string??中的位置。
? ?stop??可選。一個(gè) 非負(fù)的整數(shù) ,比要提取的子串的最后一個(gè)字符在?string??中的位置多 1。 如果省略該參數(shù),那么返回的子串會(huì)一直到字符串的結(jié)尾。

說(shuō)明

1.substring() 方法返回的子串包括 start 處的字符,但不包括 stop 處的字符。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(1,5)
< "1234"

2.如果參數(shù) start 與 stop 相等,那么該方法返回的就是一個(gè)空串(即長(zhǎng)度為 0 的字符串)。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(1,1)
< ""

3.如果 start 比 stop 大,那么該方法在提取子串之前會(huì)先交換這兩個(gè)參數(shù)。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(5,1) 
//=>a.substring(1,5)
< "1234"

4.如果 start 和 stop 有負(fù)數(shù),那么會(huì)把該參數(shù)自動(dòng)轉(zhuǎn)為0,然后繼續(xù)上述規(guī)則。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(5,-1) 
//=> a.substring(5,0) 
//=> a.substring(0,5)
< "1234"

5.如果 start 和 stop 有正小數(shù)(負(fù)數(shù)直接進(jìn)行第4條),那么會(huì)把該參數(shù)向下取整,然后繼續(xù)上述規(guī)則。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(5,2.5) 
//=> a.substring(5,2) 
//=> a.substring(2,5)
< "234"

6.如果 start 和 stop 有字符串,那么會(huì)先進(jìn)行parseInt(),如果轉(zhuǎn)換結(jié)果為NaN,那么就轉(zhuǎn)換為0,其余情況繼續(xù)上述規(guī)則。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substring(5,'2.5') 
//=> a.substring(5,2) 
//=> a.substring(2,5)
< "234"
> a.substring(5,'ss') 
//=> a.substring(5,NaN) 
//=> a.substring(5,0) 
//=> a.substring(0,5)
< "01234"

其他情況就沒(méi)有一一測(cè)試了,當(dāng)然正常情況下盡量不要這么干,畢竟語(yǔ)法上已經(jīng)規(guī)定了是整數(shù)。

substr

substr() 方法可在字符串中抽取從 start 下標(biāo)開始的指定數(shù)目的字符。

語(yǔ)法

string.substr(start,length)

參數(shù)

參數(shù)描述
start必需。要抽取的子串的起始下標(biāo)。必須是數(shù)值。如果是負(fù)數(shù),那么該參數(shù)聲明從字符串的尾部開始算起的位置。也就是說(shuō),-1 指字符串中最后一個(gè)字符,-2 指倒數(shù)第二個(gè)字符,以此類推。
length可選。子串中的字符數(shù)。必須是數(shù)值。如果省略了該參數(shù),那么返回從string的開始位置到結(jié)尾的字串。

說(shuō)明

該方法與substring()最大的區(qū)別在于第二個(gè)參數(shù)是你需要截取字符串的長(zhǎng)度,而不是位置。

1.substr() 方法返回的子串從 start 處的字符開始(包括)往后截取length長(zhǎng)度,如果超過(guò)最末端就到最末端結(jié)束。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr(1,5)
< "12345"
> a.substr(1,15) 
// 只會(huì)到最末端,多了沒(méi)用
< "123456789"

2.start可以取負(fù)值,表示從字符串尾部往頭部開始數(shù)(從右到左,注意是從1開始,比如-1 指字符串中最后一個(gè)字符),但是截取長(zhǎng)度還是從左到右,如果超過(guò)最末端就到最末端結(jié)束。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr(-4,2) 
// -4表示從右開始數(shù)第4個(gè),就是'6',然后取2個(gè)長(zhǎng)度的字符串,就是'67'
< "67"

3.如果length為負(fù)值,那么會(huì)直接當(dāng)成0處理,最終返回""。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr(4,-2) 
//=> a.substr(4,0)
< ""

4.如果start或者length為小數(shù),那么會(huì)截取小數(shù)部分。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr(1.2,5.2) 
//=> a.substr(1,5)
< "12345"

5.如果 start 和 length 有字符串,那么會(huì)先進(jìn)行parseInt(),如果轉(zhuǎn)換結(jié)果為NaN,那么就轉(zhuǎn)換為0,其余情況繼續(xù)上述規(guī)則。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.substr('aa','5') 
//=> a.substr(0,5)
< "01234"

slice

slice() 方法可提取字符串的某個(gè)部分,并以新的字符串返回被提取的部分。

語(yǔ)法

string.slice(start,end)

參數(shù)

參數(shù)描述
start必須。要抽取的片斷的起始下標(biāo)。如果是負(fù)數(shù),則該參數(shù)規(guī)定的是從字符串的尾部開始算起的位置。也就是說(shuō),-1 指字符串的最后一個(gè)字符,-2 指倒數(shù)第二個(gè)字符,以此類推。
end可選。緊接著要抽取的片段的結(jié)尾的下標(biāo)。若未指定此參數(shù),則要提取的子串包括start到原字符串結(jié)尾的字符串。如果該參數(shù)是負(fù)數(shù),那么它規(guī)定的是從字符串的尾部開始算起的位置。

說(shuō)明

該方法的兩個(gè)參數(shù)均為位置坐標(biāo),和subtring比較像,區(qū)別就是該方法支持負(fù)數(shù),并且不會(huì)交換位置,始終是從start到end,如果該區(qū)間不存在,那么返回''。

1.slice() 方法返回的子串包括 start 處的字符,但不包括end 處的字符。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.slice(1,5)
< "1234"

2.當(dāng)start或者end為負(fù)值時(shí),定位方式和substr一,從右往左數(shù),從1開始。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.slice(1,-1)
//起始點(diǎn)從第1(包括)開始,結(jié)束點(diǎn)為從右往左數(shù)第1個(gè)(不包括)
< "12345678"

3.start到end的順序始終是從左到右,如果最終start的位置在end的右邊,那么返回''。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.slice(2,1)
//2所在的位置是'2',1所在的位置是'1',從2=>1,方向相反,返回為空
< ""
> a.slice(-2,1)
//-2所在的位置是'8',1所在的位置是'1',從8=>1,方向相反,返回為空
< ""
> a.slice(-2,-1)
//-2所在的位置是'8',-1所在的位置是'9',從8=>9,方向正常,返回為'8'
< "8"

4.其他情況和substring處理方式一致 。

//chrome控制臺(tái)
> var a = '0123456789'
< undefined
> a.slice('xx','5.5')
// => a.slice(0,5)
< "01234"

總結(jié)一下

從上面測(cè)試得出結(jié)論,substring不支持負(fù)值,其他兩種方式均支持負(fù)數(shù)表示,并且是從右邊第一位開始計(jì)數(shù)。

substr的第二個(gè)參數(shù)是長(zhǎng)度,這是和其他兩種方式最大的不同之處。

slice的方向性比較強(qiáng),永遠(yuǎn)是從start=>end對(duì)應(yīng)左=>右。

以上結(jié)論均在最新谷歌瀏覽器上測(cè)試,IE和火狐未測(cè)試。

到此這篇關(guān)于詳解JS截取字符串的三個(gè)方法substring,substr,slice的文章就介紹到這了,更多相關(guān)JS截取字符串內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript使用forEach()與jQuery使用each遍歷數(shù)組時(shí)return false 的區(qū)別

    JavaScript使用forEach()與jQuery使用each遍歷數(shù)組時(shí)return false 的區(qū)別

    這篇文章主要介紹了JavaScript使用forEach()與jQuery使用each遍歷數(shù)組時(shí)return false 的區(qū)別,非常不錯(cuò),需要的朋友可以參考下
    2016-08-08
  • JS如何實(shí)現(xiàn)手機(jī)端輸入驗(yàn)證碼效果

    JS如何實(shí)現(xiàn)手機(jī)端輸入驗(yàn)證碼效果

    這篇文章主要介紹了JS如何實(shí)現(xiàn)手機(jī)端輸入驗(yàn)證碼效果,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • js判斷文本框剩余可輸入字?jǐn)?shù)的方法

    js判斷文本框剩余可輸入字?jǐn)?shù)的方法

    這篇文章主要介紹了js判斷文本框剩余可輸入字?jǐn)?shù)的方法,可實(shí)現(xiàn)直觀顯示文本框可輸入字?jǐn)?shù)的功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-02-02
  • JavaScript實(shí)現(xiàn)繼承的6種常用方式總結(jié)

    JavaScript實(shí)現(xiàn)繼承的6種常用方式總結(jié)

    JavaScript想實(shí)現(xiàn)繼承的目的:重復(fù)利用另外一個(gè)對(duì)象的屬性和方法。本文為大家總結(jié)了JavaScript實(shí)現(xiàn)繼承的6種常用方式,需要的可以參考一下
    2022-07-07
  • JS新包管理工具yarn和npm的對(duì)比與使用入門

    JS新包管理工具yarn和npm的對(duì)比與使用入門

    在2016年10月11日f(shuō)acebook 公開了新的javascript包管理工具 yarn, 用來(lái)替代目前被廣泛使用的npm(nodejs 自帶的包管理工具),本文將介紹yarn工具帶來(lái)的優(yōu)點(diǎn)和使用入門,以及對(duì)比npm解決了什么問(wèn)題,帶來(lái)哪些便利。有需要的朋友們下面來(lái)一起看看吧。
    2016-12-12
  • JS開發(fā)自己的類庫(kù)實(shí)例分析

    JS開發(fā)自己的類庫(kù)實(shí)例分析

    這篇文章主要介紹了JS開發(fā)自己的類庫(kù),結(jié)合實(shí)例形式分析了javascript開發(fā)類庫(kù)的原理、組成及實(shí)現(xiàn)方法,需要的朋友可以參考下
    2019-08-08
  • JS+CSS實(shí)現(xiàn)的經(jīng)典圓角下拉菜單效果代碼

    JS+CSS實(shí)現(xiàn)的經(jīng)典圓角下拉菜單效果代碼

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)的經(jīng)典圓角下拉菜單效果代碼,可實(shí)現(xiàn)非常經(jīng)典的圓角下拉菜單效果,涉及JavaScript動(dòng)態(tài)操作頁(yè)面元素css樣式的相關(guān)技巧,需要的朋友可以參考下
    2015-10-10
  • 淺談JavaScript 覆蓋原型以及更改原型

    淺談JavaScript 覆蓋原型以及更改原型

    下面小編就為大家?guī)?lái)一篇淺談JavaScript 覆蓋原型以及更改原型。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨過(guò)來(lái)看看吧
    2016-08-08
  • js中如何對(duì)嵌套數(shù)組進(jìn)行filter過(guò)濾

    js中如何對(duì)嵌套數(shù)組進(jìn)行filter過(guò)濾

    這篇文章主要介紹了js中如何對(duì)嵌套數(shù)組進(jìn)行filter過(guò)濾問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 在Windows上安裝Node.js模塊的方法

    在Windows上安裝Node.js模塊的方法

    Node.js逐漸升溫,很多朋友已經(jīng)開始關(guān)注。但是在Windows平臺(tái)上需要基于Cygwin安裝配置環(huán)境,讓很多人望而卻步。
    2011-09-09

最新評(píng)論