js中 substr(), substring(), slice()的區別

1、做用

  三者都是基於原字符串建立新字符串的方法。javascript

  接收一到兩個參數,第一個參數截取字符串的開始位置(字符下標,從0開始),第二個參數因方法不一樣而不一樣,後面不一樣點會說到。java

  另外,三個方法都不會修改原字符串的值。spa

2、相同點

  • 均可以傳入一個或兩個參數
  • 只傳入一個參數時,都表示從指定下標,截取字符串長度,直到字符串最後一個字符
var str = 'hello sarahshine!';

console.log(str.slice(3));          // 'lo sarahshine!'
console.log(str.substring(3));      // 'lo sarahshine!'
console.log(str.subtr(3));          // 'lo sarahshine!'

 

3、不一樣點

2.1   傳入兩個參數時,第二個參數表明的意義不一樣

  • slice ( ) 和 substring ( ) 的第二個參數,都表示截取字符串的結束位置
  • substr ( ) 的第二個參數表明的是,要截取的字符串位數
var str = 'hello sarahshine!';

console.log(str.slice(3,7));           // 'lo s'
console.log(str.substring(3,7));       // 'lo s'
console.log(str.substr(3,7));          // 'lo sara'

 

2.2  傳入的參數是負數

  • slice ( )  會把全部的負數參數加上字符串的長度值,如:str.slice(-3)   至關於 str.slice(14)
  • substring ( ) 會把全部的負數參數都轉爲0
  • substr ( ) 會把第一個參數的負值加上字符串的長度值,第二個參數的負值轉爲0   (畢竟第二個參數是要截取的字符串長度,總不能爲負數吧)
var str = 'hello sarahshine!';  //length = 17
            
//只傳入一個負數
console.log(str.slice(-3));     // 'ne!'                至關於str.slice(14)
console.log(str.substring(-3)); // 'hello sarahshine!'  至關於str.substring(0)
console.log(str.substr(-3));    // 'ne!'                至關於str.substr(14)
            
//傳入兩個負數
console.log(str.slice(-3, -1));     // 'ne'          至關於str.slice(14,16)
console.log(str.substring(-3, -1)); // ''            至關於str.substring(0,0)
console.log(str.substr(-3, -1));    // ''            至關於str.substr(14,0)
            
//傳入一正一負
console.log(str.slice(3, -4));     // 'lo sarahsh'   至關於str.slice(3,13)
console.log(str.substring(3, -4)); // 'hel'          至關於str.substring(3,0)  即(0,3)
console.log(str.substr(3, -4));    // ''             至關於str.substr(3,0)

 

以上都出自《javascript高級程序設計》 設計

相關文章
相關標籤/搜索