JavaScript截取字符串的Slice、Substring、Substr函數(shù)詳解和比較
在JavaScript中,提取子字符串主要是通過 Slice、Substring、Substr 三個(gè)方法之一。
// 語法: string.slice(start [, stop])
"Good news, everyone!".slice(5,9);
// 'news'
// substring
// 語法: string.substring(indexA [, indexB])
"Good news, everyone!".substring(5,9);
// 'news'
// substr
// 語法: string.substr(start [, length])
"Good news, everyone!".substr(5,4);
// 'news'
在三個(gè)方法之中輸入一個(gè) start 的索引參數(shù),和一個(gè)可選的 end 索引( 或 length )參數(shù)。
但他們?cè)谝恍┲匾姆矫嬗兴煌?BR>1.substr()方法從指定位置,提取指定數(shù)量的字符。
param: start 開始提取字符的位置索引,length 提取字符的數(shù)量長度。
return: 一個(gè)新的字符串。 從 start 處開始的 length 個(gè)字符。
在不同瀏覽器有不一致的表現(xiàn),現(xiàn)代瀏覽器允許 start 索引參數(shù)為負(fù)數(shù),來表示從字符串結(jié)尾處開始,提取字符的數(shù)量。但是在ie8及以下版本瀏覽器 start索引參數(shù) 最小從0開始計(jì)算?!?substr 為Web瀏覽器附加的ECMAScript特性,不建議使用時(shí) start 索引為負(fù)值】
console.log("(1): " + str.substr(1)); // (1): bcdefghij
console.log("(1,2): " + str.substr(1,2)); // (1,2): bc
console.log("(-3): " + str.substr(-3)); // (-3): hij
console.log("(-3,2): " + str.substr(-3,2)); // (-3,2): hi
console.log("(20, 2): " + str.substr(20,2)); // (20, 2):
console.log("(-20, 2): " + str.substr(-20,2)); // (-20, 2): ab
// ie8及以下
console.log("(-3): " + str.substr(-2)); // (-20, 2): hij
console.log("(-3, 2): " + str.substr(-2)); // (-20, 2): ab
2.substring() 方法用于提取字符串 一個(gè)index索引至另一個(gè)之間的子集, 或是直到字符串的結(jié)束。
param: indexA, indexB 兩個(gè)參數(shù)取值范圍為一個(gè)0 至 字符串長度之間的整數(shù)。
return: 返回一個(gè)新的字符串, 從小的索引開始 到 大的索引之間,包括小的索引位置字符,不包括大的索引位置字符。
substring 的參數(shù)是可反轉(zhuǎn)的,它總是使用小的的參數(shù)值作為開始,大的參數(shù)值作為結(jié)束。 如果參數(shù)是小于0或NaN,它被看作是0,如果參數(shù)大于字符串的長度,被視為字符串的長度值.
var anyString = "Mozilla";
// Displays "Moz"
console.log(anyString.substring(0,3));
console.log(anyString.substring(3,0));
// Displays "lla"
console.log(anyString.substring(4,7));
console.log(anyString.substring(7,4));
// Displays "Mozill"
console.log(anyString.substring(0,6));
// Displays "Mozilla"
console.log(anyString.substring(0,7));
console.log(anyString.substring(0,10));
3.slice 提取字符串的一部分。
param: beginSlice開始提取字符的位置索引,可以為負(fù),如果為負(fù)值被視為(sourceLength-beginSlice),sourceLength是字符串的長度,即:從字符串的尾部開始算起的位置endSlice 結(jié)束提取的字符的位置索引。如果省略,提取到結(jié)束。如果為負(fù)值被視為(sourceLength-endSlice)。
return: 返回一個(gè)新的字符串,從 start 開始(包括 start)到 end 結(jié)束(不包括 end)為止的所有字符。
參數(shù)都可以為負(fù),如果索引是負(fù)的,則從字符串的尾部開始算起。
var str1 = "The morning is upon us.";
console.log(str1.slice(4, -2)); // morning is upon u
var str = "The morning is upon us.";
str.slice(-3); // "us."
str.slice(-3, -1); // "us"
str.slice(0, -1); // "The morning is upon us"
- Js數(shù)組的操作push,pop,shift,unshift等方法詳細(xì)介紹
- JavaScript使用pop方法移除數(shù)組最后一個(gè)元素用法實(shí)例
- JavaScript數(shù)組函數(shù)unshift、shift、pop、push使用實(shí)例
- JS數(shù)組方法push()、pop()用法實(shí)例分析
- JS Array.slice 截取數(shù)組的實(shí)現(xiàn)方法
- JS數(shù)組操作(數(shù)組增加、刪除、翻轉(zhuǎn)、轉(zhuǎn)字符串、取索引、截取(切片)slice、剪接splice、數(shù)組合并)
- javascript中不易分清的slice,splice和split三個(gè)函數(shù)
- javascript中l(wèi)ength屬性的探索
- JavaScript中l(wèi)ength屬性的使用方法
- JavaScript 中獲取數(shù)組最后一個(gè)元素方法匯總
相關(guān)文章
js實(shí)現(xiàn)以最簡單的方式將數(shù)組元素添加到對(duì)象中的方法
下面小編就為大家分享一篇js實(shí)現(xiàn)以最簡單的方式將數(shù)組元素添加到對(duì)象中的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12javascript for-in有序遍歷json數(shù)據(jù)并探討各個(gè)瀏覽器差異
這篇文章主要介紹了javascript for-in有序遍歷json數(shù)據(jù)并探討各個(gè)瀏覽器差異的相關(guān)資料,需要的朋友可以參考下2015-11-11JS自動(dòng)生成動(dòng)態(tài)HTML驗(yàn)證碼頁面
這篇文章主要介紹了JS自動(dòng)生成動(dòng)態(tài)HTML驗(yàn)證碼頁面,輸入錯(cuò)誤自動(dòng)清空輸入框的功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06JS實(shí)現(xiàn)頁面加載完成之后自動(dòng)刷新一次問題
這篇文章主要介紹了JS實(shí)現(xiàn)頁面加載完成之后自動(dòng)刷新一次問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02JavaScript實(shí)現(xiàn)五子棋游戲的方法詳解
這篇文章主要介紹了JavaScript實(shí)現(xiàn)五子棋游戲的方法,結(jié)合實(shí)例形式詳細(xì)分析了javascript實(shí)現(xiàn)五子棋游戲的具體步驟、原理與相關(guān)操作技巧,需要的朋友可以參考下2019-07-07