이 문제를 해결하기 위해 어제 바이트 수에 따라 문자열을 가로채는 함수를 작성했습니다.
구체적인 사용법은 매우 간단합니다. String.subString(start, end)처럼 사용하면 됩니다. 예를 들면 다음과 같습니다. var str = "안녕하세요, 제가 당신을 애무해 드리겠습니다."; var str1 = str.subCHStr(2, 2) var str2 = str.subCHString(2, 4); 🎜>
코드
//문자열 계산 length
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;
}
return len;
}
//문자열을 분할하고
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)
true를 반환합니다. 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;
}
/ /가로채기 문자열(시작 바이트 길이 바이트에서 가로채기)
String.prototype.subCHStr = function(start, length){
return this.subCHString(start, start length);
}