javascript截取字串小結

來源:互聯網
上載者:User

javascript截取字串小結

   本文章收藏了多種字元截取的方法,包括常用的js截取字串,截取字串函數及常用的截取使用,非常的簡單實用,有需要的小夥伴可以參考下。

  本文總結介紹了三種使用Javascript截取字串的方法,同時也總結了兩種截取中文字串的辦法,分享一下。

  1.substring 方法

  定義和用法

  substring 方法用於提取字串中介於兩個指定下標之間的字元。

  文法

  stringObject.substring(start,stop)

  參數 描述

  start 必需。一個非負的整數,規定要提取的子串的第一個字元在 stringObject 中的位置。

  stop 可選。一個非負的整數,比要提取的子串的最後一個字元在 stringObject 中的位置多 1。如果省略該參數,那麼返回的子串會一直到字串的結尾。

  傳回值

  一個新的字串,該字串值包含 stringObject 的一個子字串,其內容是從 start 處到 stop-1 處的所有字元,其長度為 stop 減 start。

  說明

  substring 方法返回的子串包括 start 處的字元,但不包括 end 處的字元。

  如果 start 與 end 相等,那麼該方法返回的就是一個空串(即長度為 0 的字串)。

  如果 start 比 end 大,那麼該方法在提取子串之前會先交換這兩個參數。

  如果 start 或 end 為負數,那麼它將被替換為 0。

  具體使用案例:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

var str = "0123456789";

alert(str.substring(0));------------"0123456789"

alert(str.substring(5));------------"56789"

alert(str.substring(10));-----------""

alert(str.substring(12));-----------""

alert(str.substring(-5));-----------"0123456789"

alert(str.substring(-10));----------"0123456789"

alert(str.substring(-12));----------"0123456789"

alert(str.substring(0,5));----------"01234"

alert(str.substring(0,10));---------"0123456789"

alert(str.substring(0,12));---------"0123456789"

alert(str.substring(2,0));----------"01"

alert(str.substring(2,2));----------""

alert(str.substring(2,5));----------"234"

alert(str.substring(2,12));---------"23456789"

alert(str.substring(2,-2));---------"01"

alert(str.substring(-1,5));---------"01234"

alert(str.substring(-1,-5));--------""

  2.substr 方法

  定義和用法

  substr 方法用於返回一個從指定位置開始的指定長度的子字串。

  文法

  stringObject.substr(start [, length ])

  參數 描述

  start 必需。所需的子字串的起始位置。字串中的第一個字元的索引為 0。

  length 可選。在返回的子字串中應包括的字元個數。

  說明

  如果 length 為 0 或負數,將返回一個Null 字元串。

  如果沒有指定該參數,則子字串將延續到stringObject的最後。

  具體使用案例:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

var str = "0123456789";

alert(str.substr(0));---------------"0123456789"

alert(str.substr(5));---------------"56789"

alert(str.substr(10));--------------""

alert(str.substr(12));--------------""

alert(str.substr(-5));--------------"0123456789"

alert(str.substr(-10));-------------"0123456789"

alert(str.substr(-12));-------------"0123456789"

alert(str.substr(0,5));-------------"01234"

alert(str.substr(0,10));------------"0123456789"

alert(str.substr(0,12));------------"0123456789"

alert(str.substr(2,0));-------------""

alert(str.substr(2,2));-------------"23"

alert(str.substr(2,5));-------------"23456"

alert(str.substr(2,12));------------"23456789"

alert(str.substr(2,-2));------------""

alert(str.substr(-1,5));------------"01234"

alert(str.substr(-1,-5));-----------""

  3.自訂方法

  以上兩種方法只可以對英文和數字進行截取,遇到中文便無可奈何了,強制使用會導致出現亂碼的情況,經本人認證研究終於總結出了兩種能夠使用Javascript截取字串中包含中文的方法:

  第一種方法:

  ?

1

2

3

4

5

6

7

8

9

10

11

String.prototype.sub=function(n){

var r=/[^\x00-\xff]/g;

if(this.replace(r,"mm").length<=n){return this;}

var m=Math.floor(n/2);

for(var i=m;i<this.length;i++){

if(this.substr(0,i).replace(r,"mm").length>=n){

return this.substr(0,i)+"...";

}

}

return this;

}

  第二種方法:

  //截取字串 包含中文處理,參數含義:(字串,截取長度,是否增加...)

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

function subString(str, len, hasDot){

var newLength=0;

var newStr="";

var chineseRegex=/[^\x00-\xff]/g;

var singleChar='';

var strLength=str.replace(chineseRegex,'**').length;

for(var i=0;i < strLength;i++){

singleChar=str.charAt(i).toString();

if(singleChar.match(chineseRegex) != null){

newLength+=2;

}else{

newLength++;

}

if(newLength>len){

break;

}

newStr+=singleChar;

}

 

if(hasDot && strLength>len){

newStr+='...';

}

return newStr;

}

  以上使用Js截取中文字串的具體使用方法如下:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>Javascript字串截取處理總結(Js截取中文字串總結)</title>

<script language="javascript">

String.prototype.sub=function(n){var r=/[^\x00-\xff]/g;if(this.replace(r,"mm").length<=n){return this}var m=Math.floor(n/2);for(var i=m;i<this.length;i++){if(this.substr(0,i).replace(r,"mm").length>=n){return this.substr(0,i)+"..."}}return this};

function subString(str,len,hasDot){var newLength=0;var newStr="";var chineseRegex=/[^\x00-\xff]/g;var singleChar='';var strstrLength=str.replace(chineseRegex,'**').length;for(var i=0;i<strLength;i++){singleChar=str.charAt(i).toString();if(singleChar.match(chineseRegex)!=null){newLength+=2}else{newLength++}if(newLength>len){break}newStr+=singleChar}if(hasDot&&strLength>len){newStr+='...'}return newStr}

</script>

</head>

<body>

<script language="javascript">

var str='我愛www.jb51.net';

alert(str.sub(10));

alert(subString(str,10,false));

</script>

</body>

</html>

  以上所述就是本文的所有內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.