做為一個前端開發人員在網頁展示中經常會碰到,標題過長,需要截取字符串,用CSS的實現的話各種兼容問題,各種坑。
讓後台程式截一下,又各種推託,讓後台按字節截一下更是和要了後台老命一樣,最後可能只會安字符長度給你截一下,最後不好看,對不齊,還是回頭整CSS、調兼容;
有以上有感觸的前端同學默默點個讚吧。
最近接觸一個項目,後台只提供介面(json),所有頁面的資料渲染,資料綁定都交給了前端。終於,不考慮SEO,頁面所有的主動權到偶的手中了,不經意間就碰到字節截取老問題了。
網路上流傳一個Javascript簡單取得位元組長度的方法:
程式碼
複製程式碼
程式碼
String.prototype.Blength = function(){//返回字串位元組長度
複製程式碼
程式碼如下:
function getBlength(str. (var i=str.length;i--;){
n = str.charCodeAt(i) > 255 ? 2 : 1;
複製程式碼
程式碼如下:
//擴展到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 str.Blength()
}
console.log("Blength耗時:",new Date() - time1);
var time2 = new Date()
for(var i=0;iString.getBlength(str)
}
console.log("getBlength耗時:",new Date( ) - time2);
複製程式碼
程式碼如下:
str.Blength() >> 425408
String.getBlength(str) >> 425408
--效率測試開始--
Blength耗時: 1774
//簡單計算位元組長度
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 || lenif(this.getBlength(str) var lenS = len - this.getBlength(endstr)
,_lenS = 0
, _strl = 0
while (_strl 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;iString.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的耗時也差不了多少,在二分法面前,這都是一個等級的
對比之前的計算字節長度的耗時,用二分法查找截取只消耗了不到兩次字節長度的記算的時間.
最後,同學們,來挑戰一下效率吧!

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

是的,JavaScript的引擎核心是用C語言編寫的。 1)C語言提供了高效性能和底層控制,適合JavaScript引擎的開發。 2)以V8引擎為例,其核心用C 編寫,結合了C的效率和麵向對象特性。 3)JavaScript引擎的工作原理包括解析、編譯和執行,C語言在這些過程中發揮關鍵作用。

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。1)C 用于解析JavaScript源码并生成抽象语法树。2)C 负责生成和执行字节码。3)C 实现JIT编译器,在运行时优化和编译热点代码,显著提高JavaScript的执行效率。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver CS6
視覺化網頁開發工具