广

JavaScript

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

    javascript实现截取字符串功能总结(包括使用Js截取)

    2018-04-06 10:42:12 次阅读 稿源:互联网
    零七广告

    本文总结介绍了三种使用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. var str = "0123456789";  
    2. alert(str.substring(0));------------"0123456789"  
    3. alert(str.substring(5));------------"56789"  
    4. alert(str.substring(10));-----------""  
    5. alert(str.substring(12));-----------""  
    6. alert(str.substring(-5));-----------"0123456789"  
    7. alert(str.substring(-10));----------"0123456789"  
    8. alert(str.substring(-12));----------"0123456789"  
    9. alert(str.substring(0,5));----------"01234"  
    10. alert(str.substring(0,10));---------"0123456789"  
    11. alert(str.substring(0,12));---------"0123456789"  
    12. alert(str.substring(2,0));----------"01"  
    13. alert(str.substring(2,2));----------""  
    14. alert(str.substring(2,5));----------"234"  
    15. alert(str.substring(2,12));---------"23456789"  
    16. alert(str.substring(2,-2));---------"01"  
    17. alert(str.substring(-1,5));---------"01234"  
    18. alert(str.substring(-1,-5));--------""  

    2.substr 方法

    定义和用法
    substr 方法用于返回一个从指定位置开始的指定长度的子字符串。
    语法
    stringObject.substr(start [, length ])
    参数 描述
    start 必需。所需的子字符串的起始位置。字符串中的第一个字符的索引为 0。
    length 可选。在返回的子字符串中应包括的字符个数。
    说明
    如果 length 为 0 或负数,将返回一个空字符串。
    如果没有指定该参数,则子字符串将延续到stringObject的最后。
    具体使用案例:

    1. var str = "0123456789";  
    2. alert(str.substr(0));---------------"0123456789"  
    3. alert(str.substr(5));---------------"56789"  
    4. alert(str.substr(10));--------------""  
    5. alert(str.substr(12));--------------""  
    6. alert(str.substr(-5));--------------"0123456789"  
    7. alert(str.substr(-10));-------------"0123456789"  
    8. alert(str.substr(-12));-------------"0123456789"  
    9. alert(str.substr(0,5));-------------"01234"  
    10. alert(str.substr(0,10));------------"0123456789"  
    11. alert(str.substr(0,12));------------"0123456789"  
    12. alert(str.substr(2,0));-------------""  
    13. alert(str.substr(2,2));-------------"23"  
    14. alert(str.substr(2,5));-------------"23456"  
    15. alert(str.substr(2,12));------------"23456789"  
    16. alert(str.substr(2,-2));------------""  
    17. alert(str.substr(-1,5));------------"01234"  
    18. alert(str.substr(-1,-5));-----------"" 

    3.自定义方法

    以上两种方法只可以对英文和数字进行截取,遇到中文便无可奈何了,强制使用会导致出现乱码的情况,经本人认证研究终于总结出了两种能够使用Javascript截取字符串中包含中文的方法:

    第一种方法:

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

    第二种方法:

    1. //截取字符串 包含中文处理,参数含义:(字符串,截取长度,是否增加...)  
    2. function subString(str, len, hasDot){ 
    3.     var newLength=0; 
    4.     var newStr=""
    5.     var chineseRegex=/[^/x00-/xff]/g; 
    6.     var singleChar=''
    7.     var strLength=str.replace(chineseRegex,'**').length; 
    8.     for(var i=0;i < strLength;i++){  
    9.     singleChar=str.charAt(i).toString(); 
    10.     if(singleChar.match(chineseRegex) != null){  
    11.         newLength+=2; 
    12.     }else{  
    13.         newLength++; 
    14.     }  
    15.     if(newLength>len){  
    16.         break
    17.     }  
    18.     newStr+=singleChar; 
    19.     }  
    20.      
    21.     if(hasDot && strLength>len){  
    22.         newStr+='...'
    23.     }  
    24.     return newStr; 

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

    1. <html> 
    2. <head> 
    3. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
    4. <title>Javascript字符串截取处理总结(Js截取中文字符串总结)</title> 
    5. <script language="javascript"> 
    6. 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}; 
    7. 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} 
    8. </script> 
    9. </head> 
    10. <body> 
    11. <script language="javascript"> 
    12. var str='我爱www.daimajiayuan.com'
    13. alert(str.sub(10)); 
    14. alert(subString(str,10,false)); 
    15. </script> 
    16. </body> 
    17. </html> 

    零七网部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与零七网进行文章共享合作。

    零七广告
    零七广告
    零七广告
    零七广告