JavaScript字符串分割處理的方法總結(jié)
前言:
前端開發(fā)中,字符串處理是比較常見的,筆者在最近復(fù)習(xí)的過程中也把它整理了出來。
首先,先來看看js截取三姐妹substring()
、subsstr()
、slice()
1、slice(start, end)
大姐slice()、從start開始,到end結(jié)束,開始的位置從0不是1,不包括end,支持?jǐn)?shù)組分割,支持負(fù)數(shù),返回?cái)?shù)組
? ? let test = 'hello world!' ? ? console.log(test.length) ? ? console.log(test.slice(1, 9)) ? ? console.log(test.slice(6)) ? ? console.log(test.slice(9, 1)) ? ? console.log(test.slice(-2)) ? ? console.log(test.slice(0, -2)) ? ? console.log(test.slice(-4, -2)) ? ? console.log(test.slice(-2, 4))
總結(jié):
①第一個(gè)參數(shù)比第二個(gè)參數(shù)大,結(jié)果返回空字符串
②傳入?yún)?shù)是負(fù)數(shù),slice()會(huì)先做運(yùn)算 test.length + 負(fù)數(shù)參數(shù)。
2、substr(start, length)
二姐substr()、從start開始,返回length長度字符,開始的位置從0不是1,支持負(fù)數(shù),不支持?jǐn)?shù)組
? ? let test = 'hello world!' ? ? console.log(test.length) ? ? console.log(test.substr(1, 9)) ? ? console.log(test.substr(6)) ? ? console.log(test.substr(9, 9)) ? ? console.log(test.substr(20)) ? ? console.log(test.substr(-2)) ? ? console.log(test.substr(-8, 4)) ? ? console.log(test.substr(-8, 0)) ? ? console.log(test.substr(-8, -4)) ? ? console.log(test.substr(-20))
總結(jié):
①傳入?yún)?shù)超過length返回空字符串
②傳入負(fù)數(shù),則從字符串的尾部開始算起始位置,-1指最后一個(gè)字符,-2指倒數(shù)第二個(gè)字符;當(dāng)傳入的第一個(gè)參數(shù)是負(fù)數(shù)且它的絕對(duì)值超過length,這個(gè)負(fù)數(shù)轉(zhuǎn)化為0,當(dāng)傳入的第二個(gè)參數(shù)是負(fù)數(shù),等價(jià)于0,截取0個(gè)字符,返回空字符串。
3、substring(start, stop)
三姐substring()、不接受負(fù)數(shù),從 start 開始,不包括stop,開始的位置從0不是1,不支持?jǐn)?shù)組
? ? let test = 'hello world!' ? ? console.log(test.length) ? ? console.log(test.substring(1, 9)) ? ? console.log(test.substring(6)) ? ? console.log(test.substring(9, 9)) ? ? console.log(test.substring(20)) ? ? console.log(test.substring(-2)) ? ? console.log(test.substring(-8, 4)) ? ? console.log(test.substring(-8, 0)) ? ? console.log(test.substring(-8, -4)) ? ? console.log(test.substring(-20))
總結(jié):
①第二個(gè)參數(shù)==第一個(gè)參數(shù),返回空字符串
②傳入兩個(gè)參數(shù),不管在第一還是第二位置,都會(huì)將小的參數(shù)作為第一個(gè)參數(shù),較大的作為第二個(gè)參數(shù)
③任何一個(gè)參數(shù)為負(fù)數(shù)或者NaN的時(shí)候,自動(dòng)將其轉(zhuǎn)換為0
④任何一個(gè)參數(shù)大于length,按照length處理
js字符串截取三姐妹,都不會(huì)對(duì)原始的字符串進(jìn)行修改,而是返回新的子集。但是三姐妹各自有各自的個(gè)性,面對(duì)同一種參數(shù)處理的方式都是不一樣的。
4、split(separator, length)
字符按照字符串或正則分割,輸出一個(gè)數(shù)組,length表示返回的長度,不支持?jǐn)?shù)組;
//以空格為分隔符輸出數(shù)組 ? ? var str = '123 abc 1 2 3 a b c ' ? ? var arr = str.split(' ') ? ? console.log(arr)
? ? var str = '123 abc 1 2 3 a b c' ? ? var arr = str.split(' ', 4) ? ? //第二個(gè)參數(shù)表示返回?cái)?shù)組的最大長度!注意不是原來字符串的,是新輸出的數(shù)組的 ? ? console.log(arr)
5、join(separator)
將數(shù)組合并成字符串,用 separator
隔離,不支持字符串
? ? var a = ['I', 'am', 'a', 'girl', '英文名', '是', 'gaby'] ? ? var arr = a.join(',') ? ? console.log(arr)
6、splice(start, length, …args)
數(shù)組操作函數(shù),增刪改查,不支持字符串,返回?cái)?shù)組,從 start開始,刪除的length長度,并按args參數(shù)個(gè)數(shù)添加到 start位置
//刪,第一個(gè)參數(shù)為第一項(xiàng)位置,第二個(gè)參數(shù)為要?jiǎng)h除幾個(gè) 0數(shù)起 //array.splice(index,num),返回值為刪除內(nèi)容,array為結(jié)果值 ? ? var arr = ['a', 'b', 'c', 'd', 'e', 'f'] ? ? console.log(arr.splice(0, 4)) ? ? console.log(arr)
//增,第一個(gè)參數(shù)(插入位置),第二個(gè)參數(shù)(0),第三個(gè)參數(shù)(插入的項(xiàng)) //array.splice(index,0,insertValue),返回值為空數(shù)組,array值為最終結(jié)果值 ? ? var arr = ['a', 'b', 'c', 'd', 'e', 'f'] ? ? console.log(arr.splice(2, 0, 'insert')) ? ? console.log(arr)
//改 第一個(gè)參數(shù)(起始位置),第二個(gè)參數(shù)(刪除的項(xiàng)數(shù)),第三個(gè)參數(shù)(插入任意數(shù)量的項(xiàng)) //array.splice(index,num,insertValue),返回值為刪除內(nèi)容,array為結(jié)果值 ? ? var arr = ['a', 'b', 'c', 'd', 'e', 'f'] ? ? console.log(arr.splice(2, 1, 'delete'))
到此這篇關(guān)于JavaScript字符串分割處理的方法總結(jié)的文章就介紹到這了,更多相關(guān)js字符串分割處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)數(shù)字格式千分位相互轉(zhuǎn)換方法
下面小編就為大家?guī)硪黄狫S實(shí)現(xiàn)數(shù)字格式千分位相互轉(zhuǎn)換方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08Js中forEach修改原數(shù)組與sort排序經(jīng)典場景詳解
forEach是沒有返回值并且不直接改變?cè)瓟?shù)組的,今天發(fā)現(xiàn)是不能直接改變,下面這篇文章主要給大家介紹了關(guān)于Js中forEach修改原數(shù)組與sort排序經(jīng)典場景的相關(guān)資料,需要的朋友可以參考下2022-05-05uniapp微信小程序獲取當(dāng)前城市名稱逆地址解析實(shí)例教程
最近在用uni-app開發(fā)小程序,需要獲取用戶所在城市,小程序本身沒有這樣的api,那么怎么實(shí)現(xiàn)呢?下面這篇文章主要給大家介紹了關(guān)于uniapp微信小程序獲取當(dāng)前城市名稱逆地址解析的相關(guān)資料,需要的朋友可以參考下2022-11-11動(dòng)態(tài)添加option及createElement使用示例
動(dòng)態(tài)添加option在某些特殊的情況下還是比較實(shí)用的,本文有個(gè)小示例為大家介紹下createElement使用,感興趣的朋友可以參考下2014-01-01性能優(yōu)化篇之Webpack構(gòu)建代碼質(zhì)量壓縮的建議
這篇文章主要介紹了性能優(yōu)化篇之Webpack構(gòu)建代碼質(zhì)量壓縮的建議,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04JavaScript常用內(nèi)置對(duì)象用法分析
這篇文章主要介紹了JavaScript常用內(nèi)置對(duì)象用法,簡單總結(jié)分析了javascript String對(duì)象、Date對(duì)象、Math類、數(shù)組對(duì)象等常見對(duì)象的相關(guān)功能、方法與使用注意事項(xiàng),需要的朋友可以參考下2019-07-07