首页 > 语言 > JavaScript > 正文

javascript截取字符串小结

2024-05-06 16:18:57
字体:
来源:转载
供稿:网友

本文章收藏了多种字符截取的方法,包括常用的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. 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;  
  11. }  

第二种方法:

//截取字符串 包含中文处理,参数含义:(字符串,截取长度,是否增加...)

 

 
  1. function subString(str, len, hasDot){  
  2. var newLength=0;  
  3. var newStr="";  
  4. var chineseRegex=/[^/x00-/xff]/g;  
  5. var singleChar='';  
  6. var strLength=str.replace(chineseRegex,'**').length;  
  7. for(var i=0;i < strLength;i++){  
  8. singleChar=str.charAt(i).toString();  
  9. if(singleChar.match(chineseRegex) != null){  
  10. newLength+=2;  
  11. }else{  
  12. newLength++;  
  13. }  
  14. if(newLength>len){  
  15. break;  
  16. }  
  17. newStr+=singleChar;  
  18. }  
  19.  
  20. if(hasDot && strLength>len){  
  21. newStr+='...';  
  22. }  
  23. return newStr;  
  24. }  

以上使用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 strstrstrLength=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.vevb.com';  
  13. alert(str.sub(10));  
  14. alert(subString(str,10,false));  
  15. </script>  
  16. </body>  
  17. </html> 

以上所述就是本文的所有内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选