中文字符串截取的js函數(shù)代碼
更新時間:2013年04月17日 17:14:27 投稿:mdxy-dxy
有時在顯示某段文字的時候,可能會太長,影響我們頁面的顯示效果,如果僅是英文,那么我們可以用String.substring(start, end)函數(shù)就已經(jīng)夠用了,但是通常我們都會遇到既有英文,又有漢字的情況
為了解決這個問題昨天寫了根據(jù)字節(jié)數(shù)截取字符串的函數(shù)。
復(fù)制代碼 代碼如下:
Code
//計算字符串長度
String.prototype.strLen = function() {
var len = 0;
for (var i = 0; i < this.length; i++) {
if (this.charCodeAt(i) > 255 || this.charCodeAt(i) < 0) len += 2; else len ++;
}
return len;
}
//將字符串拆成字符,并存到數(shù)組中
String.prototype.strToChars = function(){
var chars = new Array();
for (var i = 0; i < this.length; i++){
chars[i] = [this.substr(i, 1), this.isCHS(i)];
}
String.prototype.charsArray = chars;
return chars;
}
//判斷某個字符是否是漢字
String.prototype.isCHS = function(i){
if (this.charCodeAt(i) > 255 || this.charCodeAt(i) < 0)
return true;
else
return false;
}
//截取字符串(從start字節(jié)到end字節(jié))
String.prototype.subCHString = function(start, end){
var len = 0;
var str = "";
this.strToChars();
for (var i = 0; i < this.length; i++) {
if(this.charsArray[i][1])
len += 2;
else
len++;
if (end < len)
return str;
else if (start < len)
str += this.charsArray[i][0];
}
return str;
}
//截取字符串(從start字節(jié)截取length個字節(jié))
String.prototype.subCHStr = function(start, length){
return this.subCHString(start, start + length);
}
相關(guān)文章
自適應(yīng)布局meta標簽中viewport、content、width、initial-scale、minimum-sca
這篇文章主要介紹了移動客戶端手機頁面布局時各標簽元素作用和適用情景,通過詳解幾種屬性讓讀者更明確自適應(yīng)布局的注意點,具體操作步驟大家可查看下文的詳細講解,感興趣的小伙伴們可以參考一下。2017-08-08