在JavaScript中,提取子字符串主要是通過 Slice、Substring、Substr 三個方法之一。
代碼如下:
// substring
// 語法: string.substring(indexA [, indexB])
"Good news, everyone!".substring(5,9);
// 'news'
// substr
// 語法: string.substr(start [, length])
"Good news, everyone!".substr(5,4);
// 'news'
但他們在一些重要的方面有所不同:
1.substr()方法從指定位置,提取指定數(shù)量的字符。
param: start 開始提取字符的位置索引,length 提取字符的數(shù)量長度。
return: 一個新的字符串。 從 start 處開始的 length 個字符。
在不同瀏覽器有不一致的表現(xiàn),現(xiàn)代瀏覽器允許 start 索引參數(shù)為負數(shù),來表示從字符串結(jié)尾處開始,提取字符的數(shù)量。但是在ie8及以下版本瀏覽器 start索引參數(shù) 最小從0開始計算?!?substr 為Web瀏覽器附加的ECMAScript特性,不建議使用時 start 索引為負值】
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
// 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開始提取字符的位置索引,可以為負,如果為負值被視為(sourceLength-beginSlice),sourceLength是字符串的長度,即:從字符串的尾部開始算起的位置endSlice 結(jié)束提取的字符的位置索引。如果省略,提取到結(jié)束。如果為負值被視為(sourceLength-endSlice)。
return: 返回一個新的字符串,從 start 開始(包括 start)到 end 結(jié)束(不包括 end)為止的所有字符。
參數(shù)都可以為負,如果索引是負的,則從字符串的尾部開始算起。
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"
如對本文有疑問,請?zhí)峤坏浇涣魃鐓^(qū),廣大熱心網(wǎng)友會為你解答!! 點擊進入社區(qū)