DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 常常會用到的截取字符串substr()、substring()、slice()方法詳解
常常會用到的截取字符串substr()、substring()、slice()方法詳解
編輯:關於JavaScript     

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() 和 substring () 行為是一致的,substr()方法在第二個參數上會容易混淆

在傳遞負值參數情況下,slice() 方法是通過字符串長度相加,符合一般思維,substring()第二個參數轉換為0會容易出問題,起始位置會容易變更,

substr() 方法負值情況下會出現IE兼容性問題。

綜上,小弟一般推薦使用slice()方法。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved