作家
登录

js中根据字数截取字符串,不能截断url

作者: 来源:www.28hudong.com 2013-03-30 00:35:14 阅读 我要评论

今天收到个需求: 1,给一个文字,对输出的文字进行截取,保留400个字符 2,截取内容最后如果是url,保留完整url地址 3,添加省略号...... ---- 其中对url的保留比较麻烦,尤其是有两个相同url时不能采用indexOf获取其字符位置。 处理结果: 相关代码: 复制代码 代码如下: String.prototype.sizeAt = function(){ var nLen = 0; for(var i = 0, end = this.length; i<end; i++){ nLen += this.charCodeAt(i)>128?2:1; } return nLen; }; String.prototype.cutStr = function(n, sCut){ if(this.sizeAt() <= n){ return this; } sCut = sCut || ""; var max = n-sCut.sizeAt(); var nLen = 0; var s = this; for(var i =0,end = this.length;i<end;i++){ nLen += this.charCodeAt(i)>128?2:1; if(nLen>max){ s = this.slice(0,i); s += sCut; break; } } return s.toString(); }; String.prototype.cutStrButUrl = function(n, sCut){ if(this.sizeAt() <=n){ return this.toString(); } sCut = sCut || ""; var max = n-sCut.sizeAt(); var s = this; //查找所有包含的url var aUrl = s.match(/https?://[a-zA-Z0-9]+(.[a-zA-Z0-9]+)+([-_A-Z0-9a-z$.+!*/,:;@&=?~#%]*)*/gi); //当第max个字符刚好在url之间时,bCut会被设置为flase; var bCut = true; if(aUrl){ //对每个url进行判断 for(var i=0, endI = aUrl.length;i<endI;i++){ var sUrl = aUrl[i]; //可能出现两个相同url的情况 var aP = s.split(sUrl); var nCurr = 0; var nLenURL = sUrl.sizeAt(); var sResult = ""; for(j = 0, endJ = aP.length; j<endJ; j++){ nCurr +=aP[j].sizeAt(); sResult +=aP[j]; sResult += sUrl; //当前字数相加少于max但添加url超过max:即会截到url if(nCurr < max && nCurr + nLenURL>max){ s = sResult + sCut; bCut = false; break; } nCurr += nLenURL; } if(bCut === false){ break; } }; } if(bCut){ s = s.cutStr(n, sCut); } return s.toString(); }; console.log('正常截取20个字符'.cutStrButUrl(20,'......')); console.log('正常截取20个字符,但我超了'.cutStrButUrl(20,'......')); console.log('有url的字符串http://www.baidu.com你能截取到吗?'.cutStrButUrl(20,'......')); console.log('http://www.baidu.com有两个相同url的字符串http://www.baidu.com好吗?'.cutStrButUrl(51, '......'));

  推荐阅读

  Prototype源码浅析 String部分(四)之补充

替换 interpolate | sub | scan | truncate | gsubinterpolate : 将字符串看作一个模板,并使用 object 的属性填充它。 sub : 将字符串中前指定个个与 pattern 指定的模式匹配的子串用 replacement 替换 s>>>详细阅读


本文标题:js中根据字数截取字符串,不能截断url

地址:http://www.17bianji.com/kaifa2/JS/23722.html

关键词: 探索发现

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

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)