DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> javascript中String類的subString()方法和slice()方法
javascript中String類的subString()方法和slice()方法
編輯:關於JavaScript     
在該書2.8.4節中講到String類中的subString()方法和slice()方法,其用法和返回結果都基本相同,如下示例:
復制代碼 代碼如下:
var strObj = new String("hello world");
alert(strObj.slice(3));   // 輸出結果:"ol world"
alert(strObj.subString(3));   // 輸出結果:"ol world"
alert(strObj.slice(3, 7)); // 輸出結果:"lo w"
alert(strObj.subString(3,7)); // 輸出結果:"lo w"

由以上代碼的輸出結果可已看出,slice()方法和subString()方調用方法法和輸出結果完全一樣,這兩種方法返回的都是要處理的字符串的子串,都接受一個或兩個參數,第一個參數是要獲取的子串的起始位置,第二個參數是要獲取子串的終止位置,如果第二個參數省略終止位置就默認為字符串的長度,且兩個方法都不改變String對象自身的值。

為什麼有兩個功能完全相同的方法呢?事實上,這兩個方法並不完全相同,不過只在參數為負值時,他們處理參數的方式稍有不同。

對於負數參數,slice()方法會用字符串的長度加上參數,subString()方法將其作為0處理,例如:
復制代碼 代碼如下:
var strObj = new String("hello world");
alert(strObj.slice(-3));      // 輸出結果:"rld"
alert(strObj.subString(-3));    // 輸出結果:"hello world"
alert(strObj.slice(3,-4));     // 輸出結果:"lo w"
alert(strObj.subString(3,-4))   // 輸出結果:"hel"

這樣既可看到slice()和subString()方法的主要不同。當只有參數-3時,slice()返回"rld",subString()則返回"hello world"。這是因為對於字符串"hello world",slice(-3)將被轉換成slice(8),而subString(-3)則轉化成subString(0)。同樣,使用3和-4差別也是很明顯。slice()方法將被轉換成slice(3,7),與前面的例子相同,返回"lo w"。而subString()方法則將這個兩個參數解釋為subString(0,3),實際上是:subString(0,3),因為subString()總是把較小的參數作為起始位,較大的數字最為終止位。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved