실제로 문제는 js 자체가 유니코드로 인코딩된 경우 정규식 s를 사용하여 모든 공백을 제거할 수 있지만 js가 utf-8로 인코딩된 경우 정규식은 160으로 인코딩된 공백을 처리할 수 없다는 것입니다.
아래에서는 먼저 정규식을 사용하여 32로 코딩된 공백을 제거한 다음 재귀적 방법을 사용하여 문자열 양쪽의 유니코드 공백을 제거합니다.
/**문자 양쪽 끝의 공백 제거 시작
*@author Ao Shiwei
*@version v1.0
*@date 2009/11/14 22:51
*/
String .prototype.trim = function() {
var r = this.replace(/(^s*)|(s*$)/g, "");
r = Lremoveblank(r) ;
r = Rremoveblank(r);
return r;
}
function Lremoveblank(s) {
if (s.length == 1 && s.charCodeAt(0) ) == 160)
return "";
if (s.charCodeAt(0) == 160) {
s = s.substr(1, s.length - 1)
return Removeblank(s );
}
else {
return s;
}
}
function Rremoveblank(s) {
if (s.length == 1 && s .charCodeAt(0) == 160)
return "";
if (s.charCodeAt(s.length-1) == 160) {
s = s.substr(0, s.length - 1);
removeblank(s)
}
else {
return s
}
//-둘 다 제거 공백으로 끝나는 문자
//예:
var a = " a
alert("b" a.trim() "b");