JS按字節(jié)截取字符長(zhǎng)度實(shí)例
更新時(shí)間:2013年11月20日 16:00:40 投稿:shangke
這篇文章主要介紹了JS按字節(jié)截取字符長(zhǎng)度實(shí)例,有需要的朋友可以參考一下
*
* 處理過長(zhǎng)的字符串,截取并添加省略號(hào)
* 注:半角長(zhǎng)度為1,全角長(zhǎng)度為2
*
* pStr:字符串
* pLen:截取長(zhǎng)度
*
* return: 截取后的字符串
*
復(fù)制代碼 代碼如下:
function autoAddEllipsis(pStr, pLen) {
var _ret = cutString(pStr, pLen);
var _cutFlag = _ret.cutflag;
var _cutStringn = _ret.cutstring;
if ("1" == _cutFlag) {
return _cutStringn + "...";
} else {
return _cutStringn;
}
}
*
* 取得指定長(zhǎng)度的字符串
* 注:半角長(zhǎng)度為1,全角長(zhǎng)度為2
*
* pStr:字符串
* pLen:截取長(zhǎng)度
*
* return: 截取后的字符串
*
復(fù)制代碼 代碼如下:
function cutString(pStr, pLen) {
// 原字符串長(zhǎng)度
var _strLen = pStr.length;
var _tmpCode;
var _cutString;
// 默認(rèn)情況下,返回的字符串是原字符串的一部分
var _cutFlag = "1";
var _lenCount = 0;
var _ret = false;
if (_strLen <= pLen/2) {
_cutString = pStr;
_ret = true;
}
if (!_ret) {
for (var i = 0; i < _strLen ; i++ ) {
if (isFull(pStr.charAt(i))) {
_lenCount += 2;
} else {
_lenCount += 1;
}
if (_lenCount > pLen) {
_cutString = pStr.substring(0, i);
_ret = true;
break;
} else if (_lenCount == pLen) {
_cutString = pStr.substring(0, i + 1);
_ret = true;
break;
}
}
}
if (!_ret) {
_cutString = pStr;
_ret = true;
}
if (_cutString.length == _strLen) {
_cutFlag = "0";
}
return {"cutstring":_cutString, "cutflag":_cutFlag};
}
*
* 判斷是否為全角
*
* pChar:長(zhǎng)度為1的字符串
* return: tbtrue:全角
* false:半角
*
復(fù)制代碼 代碼如下:
function isFull (pChar) {
for (var i = 0; i < pChar.strLen ; i++ ) {
if ((pChar.charCodeAt(i) > 128)) {
return true;
} else {
return false;
}
}
}
用例:
復(fù)制代碼 代碼如下:
testStr = "測(cè)試1字符串";
autoAddEllipsis(testStr, 1); // "測(cè)..."
autoAddEllipsis(testStr, 2); // "測(cè)..."
autoAddEllipsis(testStr, 3); // "測(cè)..."
autoAddEllipsis(testStr, 4); // "測(cè)試..."
autoAddEllipsis(testStr, 5); // "測(cè)試1..."
autoAddEllipsis(testStr, 6); // "測(cè)試1..."
autoAddEllipsis(testStr, 7); // "測(cè)試1字..."
相關(guān)文章
JS實(shí)現(xiàn)圖片輪播效果實(shí)例詳解【可自動(dòng)和手動(dòng)】
這篇文章主要介紹了JS實(shí)現(xiàn)圖片輪播效果,結(jié)合完整實(shí)例形式分析了javascript可自動(dòng)和手動(dòng)輪播圖的原理、布局與輪播功能相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-04-04JavaScript高級(jí)程序設(shè)計(jì)閱讀筆記(五) ECMAScript中的運(yùn)算符(一)
ECMAScript中的運(yùn)算符,學(xué)習(xí)js的朋友可以看看2012-02-02為網(wǎng)站代碼塊pre標(biāo)簽增加一個(gè)復(fù)制代碼按鈕代碼
寫文章的時(shí)候,作為一名專業(yè)的碼農(nóng),經(jīng)常會(huì)在文章中粘貼一些代碼。有的時(shí)候代碼塊比較長(zhǎng),在后期使用中需要復(fù)制這段代碼就比較麻煩2021-11-11js向上無縫滾動(dòng),網(wǎng)站公告效果 具體代碼
這篇文章主要介紹了js向上無縫滾動(dòng),網(wǎng)站公告效果,有需要的朋友可以參考一下2013-11-11