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

來源:互聯網
上載者:User

標籤:程式設計   rip   截取字串   不能   作用   相同   log   開始   字串   

一、作用

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

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

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

二、相同點
  • 都可以傳入一個或兩個參數
  • 只傳入一個參數時,都表示從指定下標,截取字串長度,直到字串最後一個字元
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!‘

 

三、不同點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進階程式設計》 

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.