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을 이용하는 방법으로 구현하는것이 최선의 방법이 아닐까 한다.

 

번호 제목 글쓴이 날짜 조회 수
77 [펌] TAEYO.NET - JavaScript OOP 스트레칭 황제낙엽 2009.04.02 27
76 Rhino scopes and contexts 에 대한 문서 황제낙엽 2008.07.18 27
75 Fetch API (CORS 극복을 위한 노력) 황제낙엽 2021.12.05 26
74 유용한 자바스크립트 예제 몇가지 (Tree 및...) file 황제낙엽 2005.10.20 26
73 링크모음 황제낙엽 2011.03.25 25
72 YUI Logger(Yahoo) 를 동적으로 로드하는 북마크릿 황제낙엽 2010.10.03 25
71 생성자 체인과 상속 황제낙엽 2008.08.08 24
70 Date객체 - 날짜구하기 file 황제낙엽 2008.02.19 24
69 CORS(Cross-Origin Resource Sharing) - 2 황제낙엽 2017.03.07 24
68 연산자 this 황제낙엽 2014.12.30 23
67 URI 인코딩을 해야 하는 문자들 황제낙엽 2009.09.02 23
66 [펌] 아사페릴의 사생활 - __proto__ 와 construct 와 prototype 황제낙엽 2009.04.02 23
65 String xml 파싱 황제낙엽 2008.11.03 23
64 XML+JS 연동 다중셀렉트박스 (1) - <font color="brown">(MS Explorer 전용)</brown> 황제낙엽 2005.12.02 23
63 파이어폭스로 스크립트 디버깅하기 황제낙엽 2009.01.14 22
62 동적인 언어를 동적으로 호출하기 file 황제낙엽 2008.07.14 22
61 [펌] TAEYO.NET - JavaScript OOP 코어객체와 prototype를 사용한 객체확장 황제낙엽 2009.04.02 21
60 Object 와 Prototype 황제낙엽 2008.08.08 21
59 [펌]자바스크립트에서 객체 생성 방법 황제낙엽 2008.08.07 21
58 감추기, 보이기 화면 예제 황제낙엽 2008.04.14 21