JS實(shí)現(xiàn)含有中文字符串的友好截取功能分析
本文實(shí)例講述了JS實(shí)現(xiàn)含有中文字符串的友好截取功能。分享給大家供大家參考,具體如下:
在顯示字符串的時(shí)候,避免字符串過長(zhǎng)往往會(huì)對(duì)字符串進(jìn)行截取操作,通常會(huì)用到j(luò)s 的 substr 或者 substring方法, 以及 字符串的length屬性
對(duì)于非中文的字符串處理是很簡(jiǎn)單的,但是中文字符的 length 屬性值 是1 而不是 2 ,所以處理就不是很友好了。
例如 你有一個(gè)字符串 1234567890 和 一二三四五六七八九零,
你只想顯示五位長(zhǎng)度,往往會(huì)這樣操作 str = str.substr(0, 5);
但是 12345 與 一二三四五 所占的寬度是不同的,因?yàn)橹形耐?字節(jié), 為了顯示效果更好,
故封裝下面的js, 他會(huì)辨別中文字符的 length 為2
$.String.Substr = function (str, n) {//字符串截取 包含對(duì)中文處理 if (str.replace(/[\u4e00-\u9fa5]/g, "**").length <= n) { return str; } else { var len = 0; var tmpStr = ""; for (var i = 0; i < str.length; i++) {//遍歷字符串 if (/[\u4e00-\u9fa5]/.test(str[i])) {//中文 長(zhǎng)度為兩字節(jié) len += 2; } else { len += 1; } if (len > n) { break; } else { tmpStr += str[i]; } } return tmpStr + " ..."; } };
PS:這里再為大家推薦2款在線字符統(tǒng)計(jì)工具,都包含對(duì)中英文及符號(hào)的計(jì)算功能,相信對(duì)大家有一定參考借鑒價(jià)值:
在線字?jǐn)?shù)統(tǒng)計(jì)工具:
http://tools.jb51.net/code/zishutongji
在線字符統(tǒng)計(jì)與編輯工具:
http://tools.jb51.net/code/char_tongji
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript遍歷算法與技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JS字符串長(zhǎng)度判斷,超出進(jìn)行自動(dòng)截取的實(shí)例(支持中文)
- JS實(shí)現(xiàn)對(duì)中文字符串進(jìn)行utf-8的Base64編碼的方法(使其與Java編碼相同)
- JavaScript過濾字符串中的中文與空格方法匯總
- 教你如何使用PHP輸出中文JSON字符串
- JS判斷字符串長(zhǎng)度的5個(gè)方法(區(qū)分中文和英文)
- js計(jì)算字符串長(zhǎng)度包含的中文是utf8格式
- 中文字符串截取的js函數(shù)代碼
- Javascript 中文字符串處理額外注意事項(xiàng)
- 用javascript實(shí)現(xiàn)截取字符串包含中文處理的函數(shù)
- js substr支持中文截取函數(shù)代碼(中文是雙字節(jié))
相關(guān)文章
微信小程序網(wǎng)絡(luò)請(qǐng)求實(shí)現(xiàn)過程解析
這篇文章主要介紹了微信小程序網(wǎng)絡(luò)請(qǐng)求實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11javaScript中一些常見的數(shù)據(jù)類型檢查校驗(yàn)
最近在面試的時(shí)候又被問到JS中檢查校驗(yàn)數(shù)據(jù)類型的方法,所以這篇文章主要給大家介紹了關(guān)于javaScript中一些常見的數(shù)據(jù)類型檢查校驗(yàn)的相關(guān)資料,需要的朋友可以參考下2022-05-05JS數(shù)組排序技巧匯總(冒泡、sort、快速、希爾等排序)
這篇文章主要介紹了JS數(shù)組排序技巧,實(shí)例匯總了JavaScript冒泡排序、sort排序、快速排序、希爾排序等,并附帶分析了sort排序的相關(guān)注意事項(xiàng),需要的朋友可以參考下2015-11-11blob轉(zhuǎn)換成string格式同步調(diào)用問題解決分析
這篇文章主要為大家介紹了blob轉(zhuǎn)換成string格式同步調(diào)用問題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05javascript css在IE和Firefox中區(qū)別分析
我們討論的主題CSS網(wǎng)頁布局,最令大家頭疼的問題就是瀏覽器兼容性,雖然52CSS.com介紹過很多這方向的知識(shí),但依然讓很多開發(fā)人員暈頭轉(zhuǎn)向,今天的這篇文章,將列出css和javascript在IE和Firefox中二十三個(gè)不同點(diǎn),希望對(duì)大家的學(xué)習(xí)有所幫助。2009-02-02JS正則表達(dá)式常見函數(shù)與用法小結(jié)
這篇文章主要介紹了JS正則表達(dá)式常見函數(shù)與用法,結(jié)合實(shí)例形式分析了JS正則表達(dá)式基本功能、常見函數(shù)與相關(guān)使用技巧,需要的朋友可以參考下2020-04-04JavaScript無操作后屏保功能的實(shí)現(xiàn)方法
今天組里的同事要寫一個(gè)屏保的效果,要求鼠標(biāo)無操作N秒后進(jìn)入屏幕保護(hù),滑動(dòng)鼠標(biāo)的時(shí)候取消屏幕保護(hù)。我真是難倒了,糾結(jié)了半天,搞定了,下面給大家分享實(shí)現(xiàn)代碼2017-07-07防止動(dòng)態(tài)加載JavaScript引起的內(nèi)存泄漏問題
利用Script標(biāo)簽可以跨域加載并運(yùn)行一段JavaScript腳本, 但Neil Fraser先前已指出,腳本運(yùn)行后資源并沒被釋放,即使是Script標(biāo)簽移除后。2009-10-10