亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

標題過長使用javascript按字節截取字符串

2019-11-20 20:47:26
字體:
來源:轉載
供稿:網友
做為一個前端開發人員在網頁展示中經常會碰到,標題過長,需要截取字符串,用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的耗時也差不了多少,在二分法面前,這都是一個級別的

對比之前的計算字節長度的耗時,用二分法查找截取只消耗了不到兩次字節長度的記算的時間.

最后,同學們,來挑戰一下效率吧!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
4444欧美成人kkkk| 秋霞成人午夜鲁丝一区二区三区| 欧美精品制服第一页| 国产成人亚洲精品| 欧美黄色片在线观看| 国产精品视频xxxx| 91色精品视频在线| 亚洲最大的av网站| 国产日韩中文字幕| 亚洲国产精品女人久久久| 色在人av网站天堂精品| 欧美黄色片免费观看| 欧美激情视频一区二区三区不卡| 精品亚洲一区二区三区在线播放| 亚洲香蕉成人av网站在线观看| 日韩精品极品视频免费观看| 久久成人这里只有精品| 麻豆成人在线看| 日本欧美中文字幕| 国内精品久久久久久| 91免费看片网站| 日韩精品欧美激情| 色狠狠av一区二区三区香蕉蜜桃| 精品国产乱码久久久久久天美| 欧美一区二区视频97| 日韩视频免费大全中文字幕| 91成人天堂久久成人| 黑人狂躁日本妞一区二区三区| 日韩av免费在线看| 亚洲国产欧美精品| 欧美精品在线免费观看| 91av国产在线| 亚洲电影免费在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 欧美噜噜久久久xxx| 国产99视频在线观看| 激情久久av一区av二区av三区| 精品国产91久久久久久| 国产精品第10页| 欧美国产日韩xxxxx| 九色成人免费视频| 国产精品偷伦视频免费观看国产| www.欧美三级电影.com| 国产精品福利在线| 国产日韩欧美中文在线播放| 国产精品成人国产乱一区| 欧美中文在线免费| 国产精品久久久久久久app| 在线日韩中文字幕| 亚洲精品mp4| 亚洲人成在线播放| 精品久久久久久久久中文字幕| 欧美在线欧美在线| 欧美激情网站在线观看| 国内精品久久久久| 国产ts人妖一区二区三区| 国产精品一久久香蕉国产线看观看| 日韩美女视频免费看| 亚洲人成电影在线观看天堂色| 毛片精品免费在线观看| 国产视频在线观看一区二区| 日本精品免费一区二区三区| 精品中文字幕久久久久久| 久久国产精品偷| 国产香蕉一区二区三区在线视频| 国产精品偷伦免费视频观看的| 黑人巨大精品欧美一区二区三区| 国内精品久久久久久影视8| 亚洲欧洲午夜一线一品| 精品国产欧美一区二区五十路| 美日韩在线视频| 欧美激情欧美狂野欧美精品| 另类美女黄大片| 日本一区二区在线播放| 欧美激情三级免费| 亚洲wwwav| 亚洲一区二区久久久久久久| 成人写真视频福利网| 欧美日韩亚洲一区二| 亚洲精品成人免费| 国产一区二区三区直播精品电影| 欧美激情区在线播放| 国产精品美女主播| 91夜夜揉人人捏人人添红杏| 国产精品久久77777| 欧美激情一级精品国产| 久久国产视频网站| 这里只有精品在线观看| 欧美日韩成人精品| 国产精品久久久久久久久久久久久| 亚洲伊人一本大道中文字幕| 日本精品久久久久影院| 成人激情视频网| 91精品在线观| 亚洲性生活视频| 日韩精品亚洲精品| 亚洲国产又黄又爽女人高潮的| 日韩极品精品视频免费观看| 国产精品一久久香蕉国产线看观看| 欧美性xxxx在线播放| 久久色精品视频| 久久综合久久美利坚合众国| 久久人人爽人人爽人人片av高请| 国产精品中文久久久久久久| 亚洲最大av在线| 一本色道久久88精品综合| 中文字幕无线精品亚洲乱码一区| 国产精品视频一区国模私拍| 欧美午夜精品久久久久久浪潮| 国产精品午夜一区二区欲梦| 欧美视频第一页| 最近日韩中文字幕中文| 麻豆成人在线看| 欧美人在线视频| 国产精品一区二区久久精品| 91精品国产99久久久久久| 亚洲欧美成人精品| 精品国产网站地址| 日韩视频欧美视频| 日本不卡高字幕在线2019| 国产午夜精品全部视频播放| 国产视频999| 有码中文亚洲精品| 91精品综合久久久久久五月天| 亚洲色图日韩av| 91精品视频在线播放| 精品久久久久久中文字幕大豆网| 国产亚洲激情在线| 91精品国产色综合久久不卡98| 国产美女高潮久久白浆| 91精品国产综合久久香蕉的用户体验| 欧美视频在线免费看| 欧洲一区二区视频| 国产精品中文字幕久久久| 伊人伊成久久人综合网小说| 国产亚洲视频在线观看| 亚洲另类激情图| 欧美日韩一区二区在线播放| 日韩国产一区三区| 亚洲老头同性xxxxx| 97在线观看视频国产| 亚洲午夜精品久久久久久性色| 国产香蕉精品视频一区二区三区| 国产精品美腿一区在线看| 欧美有码在线观看视频| 亚洲区免费影片| 久久久久久久999精品视频| 久久久精品视频成人| 国产精品99一区| 久久99热这里只有精品国产| 中文在线资源观看视频网站免费不卡| 91精品视频网站| 欧美精品亚州精品| 91极品视频在线| 国产精品高潮呻吟视频| 亚洲欧美制服综合另类| 亚洲最大av网| 欧美日韩人人澡狠狠躁视频| 中文字幕亚洲一区二区三区| 欧美高跟鞋交xxxxhd| 国产欧美日韩中文字幕| 国产极品精品在线观看| 色偷偷av亚洲男人的天堂| 在线成人激情黄色|