首頁  >  文章  >  web前端  >  JavaScript字串操作方法和瀏覽器相容性實例詳解

JavaScript字串操作方法和瀏覽器相容性實例詳解

伊谢尔伦
伊谢尔伦原創
2017-07-25 14:32:211572瀏覽

slice()

定義:接受一個或兩個參數,第一個參數指定子字串的開始位置。第二個參數表示子字串的結束位置(不包括結束位置的字元),如果沒有傳遞第二個參數,則將字串的長度作為結束位置。

1、傳遞參數為正值情況:


var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.slice(3)); // "loWorld"
// 两个参数,7位置上的字符为"r",但不包括结束位置的字符
alert(str.slice(3,7)); // "loWo"

2、傳遞參數為負值的情況:


slice()方法会将传入的负值与字符串长度相加。
 var str ="helloWorld";
// 一个参数,与字符串长度相加即为slice(7)
alert(str.slice(-3)); // "rld"
// 两个参数,与字符串长度相加即为slice(3,6)
alert(str.slice(3,-4)); // "loW"

3、第二個參數比第一個參數值小的情況:

slice()方法傳入的第二個參數比第一個參數小的話,則傳回空字串。


var str ="helloWorld";
alert(str.slice(5,3)); // ""

4、IE相容性

在IE8瀏覽器測試下,沒啥問題,行為與現代瀏覽器一致。

substring()

定義:接受一個或兩個參數,第一個參數指定子字串的開始位置。第二個參數表示子字串的結束位置(不包括結束位置的字元),如果沒有傳遞第二個參數,則將字串的長度作為結束位置。

1、傳遞參數為正值情況:與slice()方法行為相同的


var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.substring(3)); // "loWorld"
// 两个参数,7位置上的字符为"r",但不包括结束位置的字符
alert(str.substring(3,7)); // "loWo"

2、傳遞參數為負值的情況:

substring()方法會把所有負值參數轉換成0。來看下範例:


var str ="helloWorld";
// 两个参数,-4会转换为0,相当于substring(3,0) -->即为 substring(0,3)
alert(str.substring(3,-4)); // "hel"

substring()方法會將較小的數作為開始位置,將較大的數作為結束位置。如同上面的例子substring(3,0) 與substring(0,3)是一樣效果的。

4、IE相容性

在IE8瀏覽器測試下,沒啥問題,行為與現代瀏覽器一致。

substr()

定義:接受一個或兩個參數,第一個參數指定子字串的開始位置。第二個參數跟之前的方法有些差別,表示傳回的字元個數。如果沒有傳遞第二個參數,則將字串的長度作為結束位置。來看範例:

1、傳遞參數為正值情況:


#
var str ="helloWorld";
// 一个参数,则将字符串长度作为结束位置
alert(str.substr(3)); // "loWorld"
// 两个参数,从位置3开始截取后面7个字符
alert(str.substr(3,7)); // "loWorld"

2、傳遞參數為負值的情況:

substr()方法會將負的第一個參數加上字串的長度,而將負的第二個參數轉換為0。


var str ="helloWorld";
// 将第一个负的参数加上字符串的长度--->
//即为:substr(7,5) ,从位置7开始向后截取5个字符
alert(str.substr(-3,5)); // "rld"
// 将第二个参数转换为0
// 即为:substr(3,0),即从位置3截取0个字符串,则返回空
alert(str.substr(3,-2)); // ""

3、IE相容性

substr()方法傳遞負值的情況下會出現問題,會傳回原始的字串。 IE9修復了此問題。

下面要跟大家介紹slice,substr和substring的差別

#首先,他們都接收兩個參數,slice和substring接收的是起始位置和結束位置(不包括結束位置),而substr接收的則是起始位置和要回傳的字串長度。直接看下面例子:


 var test = 'hello world';
  alert(test.slice(,));    //o w
  alert(test.substring(,));   //o w
  alert(test.substr(,));   //o world

這裡有個需要注意的地方就是:substring是以兩個參數中較小一個作為起始位置,較大的參數作為結束位置。

如:


alert(test.substring(7,4));   //o w

接著,當接收的參數是負數時,slice會將它字串的長度與對應的負數相加,結果作為參數;substr則僅是將第一個參數與字串長度相加後的結果作為第一個參數;substring則乾脆將負參數都直接轉換為0。測試程式碼如下:


var test = 'hello world';  
alert(test.slice(-));   //rld  
alert(test.substring(-));  //hello world  
alert(test.substr(-));  //rld  
alert(test.slice(,-));  //lo w  
alert(test.substring(,-)); //hel  
alert(test.substr(,-));  //空字符串

 注意:IE對substr接收負值的處理有錯,它會傳回原始字串。

以上是JavaScript字串操作方法和瀏覽器相容性實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn