sitelink1 http://blog.byuli.com/72 
sitelink2  
sitelink3  
sitelink4  
extra_vars4  
extra_vars5  
extra_vars6  

필자가 아는 replaceall(string to string) 할 수 있는 방법은 아래 3가자로 추려 볼 수 있다.

아래 방법중 가장 빠른 처리 속도를 내는 방법은 무었을까? 브라우저 별로 조사해 보았다.

 

방법 1 ) split&join을 이용하는 방법

·미리보기 | 소스복사·
 
  1. view plaincopy to clipboardprint?   
  2. TestString.split("oldword").join("newword");     
  3. TestString.split("oldword").join("newword");  

방법 2 ) 정규식을 이용한 방법

·미리보기 | 소스복사·
 
  1. view plaincopy to clipboardprint?   
  2. TestString.replace(new RegExp("oldword""gi"), "newword");     
  3. TestString.replace(new RegExp("oldword""gi"), "newword");  

 방법 3 ) 루프문을 이용한 방법

·미리보기 | 소스복사·
 
  1. view plaincopy to clipboardprint?   
  2. function roopfunc (s, findStr, newStr){      
  3.     var tmpStr = s;      
  4.     while(tmpStr.indexOf(findStr) != -1) tmpStr = tmpStr.replace(findStr, newStr);                    
  5.     return tmpStr;      
  6. }     
  7. function roopfunc (s, findStr, newStr){   
  8.  var tmpStr = s;   
  9.  while(tmpStr.indexOf(findStr) != -1) tmpStr = tmpStr.replace(findStr, newStr);       
  10.  return tmpStr;   
  11. }  

비교 방법은 5,655,000 개의 문자열을 두개의 다른 문자로 치환하는 방법으로 했다.

3가지 방법 모두를 IE6, Safari, FF3, Chrome 에서 조사 했다.

결과를 보면,

방법 3의 while 문을 이용한 방법은 모든 부라우저에서 테스트 할수 없었다.

모두 다운 되버렸다.

FF의 firebug에서는 out of memory라는 오류 메시지를 뿌려주었다.

그러므로 쓰면 안되는 방법인것이다.

방법2의 정규식을 이용한 방법은 특이하게 IE에서만 좋은 성능을 발휘했다. 

IE외에 브라우저 특히 Safari 에서는 성능이 확연하게 떨어졌다. 

파이어폭스만 그나마 나은 성능을 보여주고 있다.

방법1은 IE를 제외한 브라우저에서 모두 최고의 성능을 발휘했다.

특히 Chrome 의 경우는 다른 브라우저들에 비해 최고의 빠른 속도를 보여줬다. 

필자의 결론, 

위 각 브라우저의 성능을 테스트해본 결과 방법 1의 split&join을 이용하는 방법이 정규식을 이용한 치환방법보다 좋으나, IE의 서비스 점유율을 볼때 IE에서 최적의 성능을 보이는 방법 2의 정규식을 이용한 방법을 무시 할수는 없다.

그러므로, 개발자가 할수 있는 가장 좋은 방법은 IE때만 정규식을 치환하는 방법을 사용하고 나머지는 모두 split&join을 이용하는 방법으로 구현하는것이 최선의 방법이 아닐까 한다.

 

번호 제목 글쓴이 날짜 조회 수
86 테이블 엘리먼트 생성 스크립트 황제낙엽 2009.04.07 426
85 MS 익스플로러상에서 문제가 되는 Leak 모델 황제낙엽 2009.04.03 444
84 잘못된 종속관계 해지에 따른 메모리 누수 예제 황제낙엽 2009.04.03 346
83 [펌] TAEYO.NET - Js OOP - 나만의 프레임워크 만들기 황제낙엽 2009.04.02 301
82 [펌] TAEYO.NET - Js OOP - 사용자 정의 객체. 그리고 상속과 재사용 황제낙엽 2009.04.02 315
81 [펌] TAEYO.NET - JavaScript OOP 코어객체와 prototype를 사용한 객체확장 황제낙엽 2009.04.02 323
80 [펌] TAEYO.NET - JavaScript OOP 스트레칭 황제낙엽 2009.04.02 340
79 [펌] 아사페릴의 사생활 - 싱글톤 패턴을 지향한 Javascript Module Pattern 황제낙엽 2009.04.02 395
78 [펌] 아사페릴의 사생활 - Code Conventions for the JavaScript Programming Language 황제낙엽 2009.04.02 460
77 [펌] 아사페릴의 사생활 - __proto__ 와 construct 와 prototype 황제낙엽 2009.04.02 303
76 [펌] 아사페릴의 사생활 - prototype과 __proto__ 와 constructor 황제낙엽 2009.04.02 352
75 [펌] 아사페릴의 사생활 - __proto__ 와 prototype에 대해.. 황제낙엽 2009.04.02 293
74 [펌] 아사페릴의 사생활 - Javascript의 클래스에 관한 이야기 황제낙엽 2009.04.02 337
73 [펌] 아사페릴의 사생활 - Javascript의 constructor 와 prototype 황제낙엽 2009.04.02 438
72 [펌] prototype (2) 황제낙엽 2009.04.02 293
71 [펌] prototype (1) 황제낙엽 2009.04.02 300
70 unshift() Method 황제낙엽 2009.03.02 638
» javascript replaceall의 방법에 따른 처리 속도 비교 황제낙엽 2009.02.11 395
68 파이어폭스로 스크립트 디버깅하기 황제낙엽 2009.01.14 346
67 숫자 여부와 자리수를 체크 하는 예제 황제낙엽 2009.01.12 5484