萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> javascript截取字符串小結

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 或負數,將返回一個空字符串。

  如果沒有指定該參數,則子字符串將延續到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>
copyright © 萬盛學電腦網 all rights reserved