이 기사의 두 번째 부분에서는 jQuery 코드의 성능을 향상시키는 방법을 살펴본다. 앞 섹션에서는 jQuery를 JavaScript 라이브러리로 선택하는 것이 성능을 고려했을 때 현명한 선택이라는 점을 살펴보았다. 운이 좋아서 이 기사를 읽고 있다면 아마도 jQuery를 사용해 보고 있을 것이다. 하지만 기본 라이브러리가 빠르다고 해서 작성한 모든 코드의 품질이 좋다고 말할 수는 없다. jQuery를 사용하여 코드를 작성할 때 주의를 기울이지 않을 경우 실제로 매우 느린 코드가 작성될 수도 있기 때문이다.
이 섹션에서는 jQuery 코드의 속도를 향상시키기 위한 몇 가지 성능 조정 및 베스트 프랙티스 팁을 단계별로 설명한다.
팁 1 - 되도록이면 CLASS 대신 ID를 사용하여 검색한다.
jQuery 코드에서는 일반적으로 ID를 기준으로 요소를 검색하는 기술과 CLASS를 기준으로 요소를 검색하는 두 가지 검색 기술이 일반적으로 사용된다. JavaScript 라이브러리 전까지는 일반적인 JavaScript를 사용하여 ID를 기준으로 페이지 요소를 매우 쉽게 찾을 수 있었다. 즉, getElementById() 메소드를 사용하여 요소를 빠르게 찾을 수 있었다. 하지만 JavaScript 라이브러리를 사용하지 않고 CLASS를 찾는 작업은 까다롭기 때문에 코드를 작성할 때 필요한 경우 ID를 사용하여 클래스를 인코딩했다. jQuery를 사용하면 페이지에서 ID를 검색하는 것처럼 쉽게 CLASS를 검색할 수 있기 때문에 이들 두 검색을 서로 바꿔서 사용해도 무방할 것처럼 보이기는 하지만 여기에서 끝이 아니다. ID를 기준으로 검색하는 것이 CLASS를 기준으로 검색하는 것보다 훨씬 빠르다. jQuery는 ID를 기준으로 검색할 때 단순히 내장 getElementById() 메소드를 사용하지만 CLASS를 기준으로 일치하는 항목을 검색할 경우에는 모든 페이지 요소를 반복해야 한다. 이는 곧 페이지가 크고 복잡할수록 CLASS를 기준으로 하는 검색에 대한 응답이 매우 느려지지만 ID를 기준으로 하는 검색의 경우에는 페이지 크기가 커지더라도 성능이 저하되지 않는다.
이 데이터는 필자가 실행 중인 성능 테스트에 대한 jQuery 결과에서 지원된다. 개별 테스트 결과를 보면서 주의해서 볼 필요가 있는 jQuery 코드 부분을 찾아보자. 이 경우에는 ID를 기준으로 검색할 때와 CLASS를 기준으로 검색할 때 발생한 테스트 결과를 살펴보자(그림 5).
그림 5. ID 기준 검색과 CLASS 기준 검색 비교
이들 테스트는 동일하지 않지만 수치만 봐도 CLASS를 기준으로 검색할 때보다 ID를 기준으로 검색할 때가 매우 빠르다는 것을 알 수 있다. 이 결과가 jQuery 코드에는 어떤 영향을 주겠는가? 검색을 작성할 때 이러한 결과를 염두에 두어야 한다. ID와 CLASS 중에서 하나를 선택할 수 있다면 항상 ID를 선택해야 한다. 또한 코드의 어느 위치에서나 검색에 사용될 수 있으므로 모든 요소에 ID를 지정해야 한다는 것을 알 수 있다.
Listing 1에서는 사용자의 시스템에서 직접 실행하여 이러한 결과를 확인해 볼 수 있는 실제 jQuery 테스트를 보여 준다.
ID 테스트는 218ms만 걸린 반면 CLASS 작업은 19.9초나 걸렸다. 테스트용으로 작성된 간단한 페이지임에도 불구하고 ID 검색이 100배 가량 빠르다.
팁 2 - 최대한 많은 검색 정보를 제공한다.
jQuery에서는 여러 가지 방법으로 페이지 요소를 검색할 수 있기 때문에 원하는 페이지 요소를 가장 효과적으로 찾을 수 있는 방법을 결정하기가 쉽지 않을 때도 있다. 이 경우 사용할 수 있는 확실한 한 가지 규칙은 검색 매개변수에 최대한 많은 정보를 제공하는 것이다. 따라서 "clickable" CLASS를 가지고 있는 모든 페이지 요소를 검색하는 경우 DIV에만 CLASS가 연결되어 있다는 것을 미리 알고 있다면 검색 성능을 향상시킬 수 있다. 그러므로 "div.clickable" 검색은 훨씬 빠른 결과를 보여 준다. 그림 6에서는 이를 증명하는 결과를 보여 준다.
기본 JavaScript 코드를 보면 이는 놀라운 결과가 아니다. 이 예제에서는 요소 태그가 제공되기 때문에 CLASS 인수에 대해 일치하는 항목을 찾기 위해 검색하는 요소 수가 획기적으로 줄어들면서 ID를 기준으로 검색한 것과 거의 비슷한 속도로 성능이 향상된다.
jQuery 선택을 작성하는 개발자는 코드를 단순하게 만든다는 이유로 게으름을 피워서는 안된다. 단순함을 강조하게 되면 정확한 결과를 얻기가 어려워 진다. 검색 메커니즘을 쉽게 만들 경우에는 간단한 정보만을 입력하기가 쉽다. 하지만 항상 특히, 정보를 알고 있는 경우 최대한 많은 정보를 사용해야 한다. Listing 2에서는 좋은 예제를 보여 준다.
팁 3 - 선택자 캐싱하기
마지막 성능 팁은 거의 모든 jQuery 선택자가 jQuery 오브젝트를 리턴한다는 사실을 활용하는 것이다. 다시 말해서, 이상적인 상황에서는 함수를 데이지 체인으로 묶거나 나중에 사용할 수 있도록 결과를 캐싱하는 기능을 사용하여 선택을 한 번만 실행하면 된다. 실제 오브젝트의 용량은 데이터를 저장할 수 있는 전체 메모리 용량에 비해 작기 때문에 결과를 캐싱하는 데 부담을 느끼지 않아도 된다.
Listing 3에서는 몇 가지 예제를 통해 캐시를 활용하는 방법을 보여 준다.
성능에 관한 마지막 예제 코드에서는 이 시리즈의 첫 번째 기사에서 설명한 위젯을 사용한다(참고자료 참조). 이 위젯은 테이블의 맨 위 왼쪽에 있는 선택란으로 해당 열의 선택란을 모두 선택/선택 취소하는 데 사용된다. 이 기능은 이메일 애플리케이션에서 모든 메시지를 선택/선택 취소할 때 흔히 사용된다.
JavaScript 작업과 관련하여 속도 및 성능 문제는 결코 사소한 문제가 아니다. 앞의 테스트에서 살펴본 바와 같이 jQuery를 작성한 개발자와 브라우저의 내장 JavaScript 엔진에 관한 작업을 수행하는 개발자는 이 사실을 잘 알고 있다. 실제로 지난 6개월 동안 브라우저 개발 분야에서 가장 중요한 문제는 JavaScript 엔진 속도였다. jQuery 코드와 JavaScript 엔진 모두 속도가 획기적으로 향상되는 모습을 보여 주면서 내년에는 JavaScript 실행 속도가 급격하게 향상될 것이 확실해 보인다. 실제로 두 캠프에서 나오는 뉴스를 보면 이러한 예측이 실현될 것이라고 충분히 짐작할 수 있다. jQuery 프로젝트를 이끌고 있는 John Resig가 새로운 "Sizzle" 선택 엔진을 개발했다. 그는 완전히 새로운 선택 엔진을 작성했으며 예비 테스트 결과 Firefox에서 속도가 4배 향상된 것으로 나타났다고 주장했다. 이는 정말 대단한 속도 향상이다. 필자가 이 마지막 섹션을 쓰는 동안 실제로 Sizzle 선택 엔진이 포함된 jQuery 1.3 버전이 릴리스되었다. jQuery에서는 모든 브라우저를 고려할 경우 1.3 버전의 선택 엔진이 1.2.6 버전에 비해 49% 향상된 속도를 제공한다고 주장한다. 또한 1.3 릴리스에서는 HTML 주입(DOM에 새 요소 추가)의 성능이 6배 향상되었고 위치 지정 함수의 성능이 3배 향상되었다고도 한다. 이 기사를 마치는 날 jQuery에 대한 주요 업데이트가 릴리스되었다는 소식을 들으니 기분이 좋다.
앞에서 언급한 것처럼 JavaScript 성능과 관련하여 또 하나 중요한 특징은 브라우저가 라이브러리보다 9배나 중요하다는 사실이다. Firefox, Chrome 및 Safari는 가장 빠른 JavaScript 엔진을 제공하는 브라우저가 되기 위해 치열한 경쟁을 치루고 있다. 위 테스트 결과를 보면 현재까지는 Chrome이 Firefox에 비해 상당한 우위를 차지하고 있는 상황이다. 하지만 Firefox 3.1에 포함될 새로운 Tracemonkey JavaScript 엔진은 3.0 버전인 현재 JavaScript 엔진에 비해 20-40배 빠를 것이라고 한다. 물론 이 주장은 아직까지 검증되지 않은 예측에 불과하지만 그래도 20-40배 빠르다면 엄청난 향상임에는 틀림없다.
향후 1-2년 동안에는 JavaScript 엔진 및 라이브러리의 기본 속도가 크게 향상되면서 JavaScript를 사용하는 웹 애플리케이션의 속도도 향상될 것이며 결과적으로 가장 복잡한 애플리케이션마저도 합리적인 수준의 속도를 제공하게 될 것이다. (물론 IE6에서는 예외이다.)
JavaScript 라이브러리와 자신이 직접 작성한 JavaScript 코드 중에서 어느 것을 사용할지 결정할 때 또 하나 고려해야 할 점은 디버깅을 포함한 수많은 기능이 JavaScript 라이브러리에 포함되어 있다는 점이다. 여러 해에 걸쳐서 수백 명의 사용자가 실제로 사용해 본 라이브러리의 모든 함수와 카페인 음료를 마셔가면서 새벽 2시에 혼자서 작성한 함수 중에서 어느 함수에 대한 신뢰도가 높을까? 게다가 jQuery 라이브러리보다 빠른 코드를 작성할 수 있다고 하더라도 라이브러리를 사용함으로써 얻게 되는 모든 장점을 상쇄할 수 있을 정도로 훌륭한 성능 향상을 기대할 수 있을까? 그리고 jQuery 및 함수 라이브러리의 편리함을 모두 포기할 수 있을까? 그것도 수많은 시간과 노력을 들여서 직접 코드를 작성하기 위해서 말이다. 게다가 버그도 많을 것이고 결국에는 "괜한 헛수고"만 했다는 느낌이 들 수도 있을 것이다. 필자라면 그렇게 하지 않을 것이다.
실망할 사람도 있겠지만 마지막으로 언급할 부분은 jQuery 라이브러리를 작성하고 있는 개발자를 고려해야 한다는 것이다. 이들은 세상에서 가장 똑똑한 최고의 프로그래머에 속하는 개발자이며 그들만이 작성할 수 있는 매우 우수한 코드가 jQuery 라이브러리에 들어 있기 때문이다. 필자는 jQuery 라이브러리를 작성하고 있는 개발자가 필자보다 훨씬 더 훌륭한 프로그래머라고 생각하고 그들을 존경한다. 그들보다 내가 더 훌륭하고 빠른 코드를 작성할 수 있다는 생각은 어리석은 생각이다. 우리는 똑똑한 개발자들이 노력해서 만든 좋은 결과물을 마음껏 활용할 수 있다.
이 기사에서는 jQuery를 비롯한 여러 JavaScript 라이브러리의 성능을 대략적으로 살펴보았다. 선택 메소드에 대한 폭넓은 테스트를 통해 라이브러리 간에도 운영 속도 차이가 상당히 크다는 것을 알 수 있었다. 그리고 jQuery가 선택하기에 적합한 빠른 라이브러리 중 하나라는 점을 확인할 수 있었다. 하지만 빠른 JavaScript 라이브러리 중 하나를 선택하더라도 웹 애플리케이션을 실행하는 데 사용되는 방문자의 브라우저의 영향이 웹 애플리케이션의 성능에 9배 더 크게 작용한다는 점도 살펴보았다. 사용자에게 특정 웹 브라우저를 사용하도록 안내할 수 있다면 그렇게 하는 것이 좋다. 웹 애플리케이션을 가장 빠르게 실행하는 브라우저를 찾은 후 웹 애플리케이션의 성능을 최대한으로 누릴 수 있도록 사용자에게 해당 브라우저를 추천할 수 있다. @@@이상적인 방법은 가장 느린 JavaScript 브라우저를 제거하고 새로운 차원의 웹 애플리케이션을 작성하는 것이다.@@@
jQuery 작업에 적용할 수 있는 세 가지 성능 팁에 대해서도 설명했다. 앞에서 설명한 대로 더 많은 팁을 제공하는 사이트도 있기는 하지만 이 기사에서 설명하는 세 가지 팁은 성능 향상과 관련하여 가장 "효과적인" 방법이다. 게다가 50가지 팁보다는 3가지 팁이 기억하기도 쉽다. 물론 다른 팁들도 유용하기 때문에 몇 가지 팁을 참고자료에서 소개하고 있다. 하지만 이러한 세 가지 팁을 염두에 두고 코드를 살펴보면 성능이 꽤 많이 향상되는 결과를 얻게 될 것이다. 항상 기억해야 하는 세 가지 jQuery 팁 중 첫 번째 팁은 CLASS보다는 ID를 기준으로 검색하는 방법이 100배 빠르다는 것이며, 두 번째 팁은 항상 되도록 많은 정보를 검색에 제공하라는 것이며, 마지막 팁은 가능한 한 선택을 캐싱하라는 것이다.
마지막으로 jQuery 및 브라우저의 JavaScript 엔진과 관련하여 앞으로 선보일 변화를 간단히 살펴보았다. 이 기사를 마무리하던 당시에 선택을 비롯하여 코드와 관련된 여러 가지 기능이 크게 향상될 것으로 예견되었던 jQuery 1.3이 릴리스되었다. 그리고 Firefox에서 20-40배 빠른 차세대 JavaScript 엔진을 장담했다는 것도 살펴보았다. 이러한 모든 사항을 종합해 보면 앞으로 1-2년 내에 매우 빠른 JavaScript 환경이 기대된다. 결과적으로 매우 크고 복잡한 웹 애플리케이션을 빠르게 실행할 수 있는 환경이 실제로 갖춰지면서 이러한 웹 애플리케이션이 더 많아질 것이라는 점도 예상할 수 있다.
지금까지 살펴본 테스트 결과를 보면 이 기사의 동기가 된 이메일에 언급되었던 "간단한 페이지에서는 jQuery가 좋지만 복잡한 페이지에서는 성능이 아주 나쁘기에 성능 문제가 해결되기 전까지는 복잡한 페이지에 JavaScript를 사용해야 한다"라는 의견에는 분명 재고의 여지가 있다. 필자가 살펴본 바에 따르면 jQuery의 "성능 문제"는 "일반적인 JavaScript" 자체에도 있는 문제이다. 실제 성능 문제는 jQuery 또는 JavaScript보다는 브라우저 자체와 관련된 부분이 많다. 따라서 설계가 좋지 않은 jQuery 코드로 구성된 복잡한 페이지를 IE6에서 실행한다면 좋은 성능을 기대하기 어렵다는 의견에 필자도 동의한다. 하지만 최소한의 성능 팁을 고려하여 작성된 좋은 jQuery라면 매우 복잡한 페이지라고 하더라도 좋은 브라우저에서 특별한 성능 문제 없이 실행할 수 있다는 점도 살펴보았다.
출처 : http://www.ibm.com/developerworks/kr/library/wa-aj-advjquery_2/
'웹 개발' 카테고리의 다른 글
javascript replaceall (0) | 2019.08.15 |
---|---|
jquery 성능 향상 방법 25가지 (0) | 2019.08.15 |
jQuery 성능 향상 방법 (0) | 2019.08.15 |
[java] request.getRemoteAddr()가 ipV6를 반환할 때 ipV4로 변경하는 방법 (0:0:0:0:0:0:0:1 to 127.0.0.1) (0) | 2019.08.15 |
iframe 또는 dialog안의 문서인지 아닌지 구분할때 (0) | 2019.08.15 |