做为一个前端开发人员在网页展示中经常会碰到,标题过长,需要截取字符串,用CSS的实现的话各种兼容问题,各种坑。
让后台程序截一下,又各种推托,让后台按字节截一下更是和要了后台老命一样,最后可能只会安字符长度给你截一下,最后不好看,对不齐,还是回头整CSS、调兼容;
有以上有感触的前端同学默默点个赞吧。
最近接触一个项目,后台只提供接口(json),所有页面的数据渲染,数据绑定都都交给了前端。终于,不考虑SEO,页面所有的主动权到偶的手中了,不经意间就碰到字节截取老问题了。
网络上流传一个Javascript简单获取字节长度的方法:
复制代码 代码如下:
String.prototype.Blength = function(){//返回字符串字节长度
return this.replace(/([^\x00-\xFF])/g, "aa").length;
};
确实很简单,大于ASCII码的字符都算做两个字节,虽然严格来说不正确,但我们是用来辅助展示效果的,真严格起来反而不好了,
但总感觉为了一点投机取巧,而用正则这种较耗时东西不太好,其实也就节省了两行代码,所以我决定还是用正常方式计算:
复制代码 代码如下:
function getBlength(str){
for(var i=str.length;i--;){
n += str.charCodeAt(i) > 255 ? 2 : 1;
}
return n;
}
我并没有把方法扩展到String对像的原型上去,还是因为效率问题,以下是测试代码:
复制代码 代码如下:
//扩展到String的prototype上
String.prototype.Blength = function () {
var str = this,
n = 0;
for (var i = str.length; i--; ) {
n += str.charCodeAt(i) > 255 ? 2 : 1;
}
return n;
}
//给String对像增加一个方法
String.getBlength = function (str) {
for (var i = str.length, n = 0; i--; ) {
n += str.charCodeAt(i) > 255 ? 2 : 1;
}
return n;
}
//先构造一个中英混合的长字符串
var str = "javascript 高效按字节截取字符串方法 getBlengthjavascript 高效按字节截取字符串方法 getBlength";
str = str.replace(/./g, str).replace(/./g, str);
console.log("创造的字符串长度为:",str.length)
console.log("-------------测试开始--------------")
console.log("str.Blength() >> ",str.Blength())
console.log("String.getBlength(str) >> ",String.getBlength(str))
console.log("--效率测试开始--")
var time1 = new Date()
for(var i=0;i<100;i++){
str.Blength()
}
console.log("Blength耗时:",new Date() - time1);
var time2 = new Date()
for(var i=0;i<100;i++){
String.getBlength(str)
}
console.log("getBlength耗时:",new Date() - time2);
结果效率差的不是一点半点,至于原因可能时间花费在了原型链的检索上了,我没有深究,知道的可以留言告诉我:
创造的字符串长度为: 314432
-------------测试开始--------------
复制代码 代码如下:
str.Blength() >> 425408
String.getBlength(str) >> 425408
--效率测试开始--
Blength耗时: 1774
getBlength耗时: 95
现在要截取字符串的基础函数有了,因为在这种情况下字符占的字节长度最长为2,所以用二分法来找到合适截取位置是再好不过了。
给一个效率应该算不错的截取函数:
复制代码 代码如下:
//简单计算字节长度
String.getBlength = function (str) {
for (var i = str.length, n = 0; i--; ) {
n += str.charCodeAt(i) > 255 ? 2 : 1;
}
return n;
}
//按指定字节截取字符串
String.cutByte = function(str,len,endstr){
var len = +len
,endstr = typeof(endstr) == 'undefined' ? "..." : endstr.toString();
function n2(a){ var n = a / 2 | 0; return (n > 0 ? n : 1)} //用于二分法查找
if(!(str+"").length || !len || len<=0){return "";}
if(this.getBlength(str) <= len){return str;} //整个函数中最耗时的一个判断,欢迎优化
var lenS = len - this.getBlength(endstr)
,_lenS = 0
, _strl = 0
while (_strl <= lenS){
var _lenS1 = n2(lenS -_strl)
_strl += this.getBlength(str.substr(_lenS,_lenS1))
_lenS += _lenS1
}
return str.substr(0,_lenS-1) + endstr
}
拿上面的字符串来测试一下,应该是载得越长越耗时,截个20W的长度试试:
复制代码 代码如下:
console.log("创造的字符串长度为:",str.length," 字节长度为:",String.getBlength(str))
console.log("-------------测试开始--------------")
console.log("String.cutByte('1开始1',6,'...') >> ",String.cutByte('1开始1',6,'...'))
console.log("String.cutByte(str,12,'...') >> ",String.cutByte(str,12,'...'))
console.log("String.cutByte(str,13,'..') >> ",String.cutByte(str,13,'..'))
console.log("String.cutByte(str,14,'.') >> ",String.cutByte(str,14,'.'))
console.log("String.cutByte(str,15,'') >> ",String.cutByte(str,15,''))
console.log("--效率测试开始--")
var time1 = new Date()
for(var i=0;i<100;i++){
String.cutByte(str,200000,'...')
}
console.log("耗时:",new Date() - time1);
输出结果:
创造的字符串长度为: 314432 字节长度为: 425408
-------------测试开始--------------
复制代码 代码如下:
String.cutByte('1开始1',6,'...') >> 1开始1
String.cutByte(str,12,'...') >> javascrip...
String.cutByte(str,13,'..') >> javascript ..
String.cutByte(str,14,'.') >> javascript 高.
String.cutByte(str,15,'') >> javascript 高
--效率测试开始--
耗时: 155
其实把截取字符长度改到30W 40W的耗时也差不了多少,在二分法面前,这都是一个级别的
对比之前的计算字节长度的耗时,用二分法查找截取只消耗了不到两次字节长度的记算的时间.
最后,同学们,来挑战一下效率吧!
相关推荐:
为什么要年前做SEO,企业为什么做seo推广 ,云南ai大数据公司
什么是seo如何进行seo,何谓seo ,红米的AI摄影什么意思
SEO新闻:2025年最新趋势与最佳实践,你不可错过的SEO战略,郑州网络营销推广的优势
SEO在线服务-让您的网站快速跃升至搜索引擎前列,江西小红书营销推广案例
AI免费生成:开启智能创作新纪元,助力你的创意无限可能
ChatGPTO1Pro模型:开启AI新纪元,免费应用带来无尽可能,苹果上的ai写作在哪里
优化平台:让数字化转型更简单、更高效,莆田谷歌seo品牌排行
ChatGPT-01:开创人工智能新纪元,AI如何画模糊的云层
SEO售产-数字营销新战场,助力企业实现盈利增长,去哪找自贡网站建设
seo软文用什么论坛,seo软文是什么意思 ,爱字幕的AI变脸不见了
seo能解决什么问题,seo会遇到哪些问题 ,挚爱花嫁ai
SEO教研:数字营销新趋势,提升网站流量与转化率的关键,齐鲁证券网站建设
seo都有什么意思,seo 啥意思 ,ai园林
AI网页效果生成:开启网站设计的新纪元,ai画线祥云
AI写作免费一键生成5000字:高效创作的革命性工具
AI优化文章:如何利用人工智能提升写作效率和质量
用AI写文,开启创作新时代
ChatGPT:我目前无法查看或解析附件,您是否遇到过这样的困扰?,ai+燃烧
seo黑帽是什么,列举几种seo黑帽行为 ,穿老款的ai丢人吗
360排名优化价格:打造高效网络营销的制胜法宝,ai换脸刘浩存自wei
SEO开发:数字营销的核心驱动力,园区网站建设
seo站内优化包括什么营销,seo站内优化操作流程 ,ai 玻璃图标
seo网站自学看什么书,seo技术适合自学吗 ,斑马ai阅读
SEO每日:提高网站流量的秘密武器,助你脱颖而出,seo优化和排名技巧
打造高效创作体验,写文章AI软件重塑内容生产力
ZBlog:开启你的个人网站新时代,轻松搭建与管理,二手手机营销推广方案
2025年SEO最新技术:让你的网站脱颖而出!,ai少女特色
SEO好吗?助力网站成功的关键之道,网站优化方案范文怎么写
AI软件不用登录,让你的工作更高效轻松,智能ai写作改稿怎么改
SEO与SEM策略:提升网站流量与品牌曝光的双剑合璧,ai补图
ChatGPT:打破语言障碍,理解与沟通的新时代,交通轨道ai
为什么做seo的人很少,为了什么做seo ,ai不负你
打造内容创作新高度:文章扩写AI的革命性优势
SEO收费如何选择合适的SEO服务,提升网站排名并增加曝光度,做网站优化哪家实惠
GPT-3.5免费吗?揭秘AI智能助手的未来与收费模式,ai 美美
AI热门软件,未来科技的钥匙
高效创作新时代AI文案速写工具,让创作更轻松
SEO部:开启数字化营销新纪元的幕后英雄,株洲营销推广是什么公司
什么是亚马逊seo策略,亚马逊的seo推广是什么 ,天天学术ai写作优惠券
ChatGPT怎么有梯子?突破网络限制,轻松畅享AI智能,ai对唱音响
seo网络推广是什么,seo网络推广是什么意思 ,ai哪里注音
一键创作,助你轻松实现创意梦想,最低价刷粉网站推广
中外链:打通全球流量的桥梁,提升网站排名与流量的双重保障,行业网站建设思路
ChatGPT桌面应用安装了,不能用?解决方案全攻略,让你轻松畅享AI助手!,绫波丽ai智能
SEO优化关键词品牌:如何通过精准的关键词提升品牌价值,ai免费智能写作论文
《SEO教材:打造网站流量的核心利器,教你轻松SEO优化技巧》,咖啡网站建设总结文案
ChatGPT:人工智能对话新时代的领航者,ai音响华为还是小米好
揭开“好的AI软件”背后的秘密:让生活和工作更智能的利器
GoogleSEO打满分自然流量会高吗?揭开SEO优化的真相,猪插画ai
SEO快速优化文章排名:提升网站流量的必备技巧,ai小苹果会员分享