구체적인 구현을 모르고 jQuery를 사용하는 수준에만 머물면 문제가 발생하기가 정말 쉽습니다. 이것이 제가 최근에 jQuery를 별로 좋아하지 않는 이유입니다. 이 프레임워크의 API 설정은 사람들을 잘못된 길로 인도하는 것으로 의심됩니다.
$.fn.beautifyTable = function(options ) {
//기본 구성 항목을 정의한 다음 옵션으로 재정의합니다.
return this.each(function() {
var table = $(this),
tbody = table.children ('tbody'),
tr = tbody.children('tr'),
th = tbody.children('th'),
td = tbody.children('td'); >//단일 콘텐츠 클래스
table.addClass(option.tableClass);
th.addClass(options.headerClass); //1
td.addClass(options.cellClass) //2
//홀수 및 짝수 행 클래스
tbody.children('tr:even').addClass(options.evenRowClass); //3
tbody.children('tr:odd').addClass(options. oddRowClass); //4
//Alignment
tr.children('th,td').css('text-align', options.align); //5
//마우스 호버 추가
tr.bind('mouseover', addActiveClass); //6
tr.bind('mouseout', RemoveActiveClass) //7
//색상을 변경하려면 클릭
tr.bind( '클릭', 전환클릭클래스); //8
})
일반적으로 이 코드는 좋고, 아이디어도 명확하고, 논리도 명확하고, 하고 싶은 일이 댓글을 통해 명확하게 설명되어 있습니다. 하지만 저자에 따르면 테이블에 120개의 행이 있을 때 IE는 이미 스크립트 실행 시간이 너무 길다는 점을 반영했다고 합니다. 분명히 성능의 관점에서 볼 때 이 기능의 효율성은 높지 않거나 심지어 극도로 낮습니다.
그래서 코드 수준부터 분석을 시작했습니다. 이는 표준 jQuery 플러그인 함수입니다. return this.each(function( ) { .. };) 형식의 일반적인 코드가 있습니다. ; 작성자가 이 코드를 작성할 때 아무 생각 없이 스크립트를 따르지 않았다면 jQuery의 기능이 무엇인지 깨달았어야 했습니다.
간단히 말하면 jQuery.fn에 있는 대부분의 함수는 각각에 대한 호출입니다. 소위 말하는 각각은 자연스럽게 선택한 요소를 탐색하고 요소에 대해 지정된 작업을 수행합니다. 따라서 위의 코드를 살펴보고 얼마나 많은 순회가 수행되었는지 확인하세요. 120개의 행만 선택되었고 각 행에는 6개의 열과 1개의 헤더 행이 있다고 가정해 보겠습니다.
Traverse th, headerClass의 수를 추가합니다. 요소는 6입니다.
td를 트래버스하고 cellClass를 추가합니다. 요소 수는 6*120=720입니다.
모든 tr에서 홀수를 찾으려면 모든 tr을 한 번 순회해야 하며 요소 수는 120개입니다.
홀수 tr을 순회하고 evenRowClass를 추가하면 요소 수는 120/2=60입니다.
모든 tr에서 짝수를 찾으려면 모든 tr을 한 번 순회해야 하며 요소 수는 120개입니다.
짝수 tr을 순회하고,oddRowClass를 추가하면 요소 수는 120/2=60입니다.
th와 td를 모두 순회하고 text-align을 추가하면 요소 수는 120*6 6=726입니다.
모든 tr을 탐색하고 마우스 오버 이벤트를 추가하며 요소 수는 120입니다.
모든 tr을 탐색하고 mouseout 이벤트를 추가합니다. 요소 수는 120입니다.
모든 tr을 탐색하고 클릭 이벤트를 추가하며 요소 수는 120입니다.
편의상 단순히 순회 중에 요소에 액세스하는 데 10ms가 걸린다고 가정합니다. 그러면 이 기능에는 총 얼마나 걸리는가요? 이 함수는 총 2172개의 요소를 발견했으며 21720ms, 즉 21초가 걸렸습니다. 분명히 IE는 스크립트가 너무 오래 걸렸다고 보고해야 합니다.
이제 효율성이 낮은 이유를 알았으니 근본적으로 해결해야 합니다. 당연히 코드에 있는 주석의 숫자에 따라 루프를 병합하는 방법을 찾아야 합니다. 위에서는 최소한 다음 사항을 병합할 수 있습니다.
3과 4를 하나의 주기로 결합할 수 있습니다(120 60 120 60에서 120, 240으로 감소). 1, 2 및 5를 하나의 주기로 결합할 수 있습니다. 6 720 726에서 726으로, 726이 감소합니다. 6. 7과 8을 하나의 주기로 결합하여 120 120 120에서 120으로 변경하면 240이 감소합니다. 또한 3, 4와 6, 7, 8을 하나의 주기로 결합할 수 있으며, 이는 계속해서 120씩 감소됩니다. 누적적으로 총 240 726 240 120 = 1326 요소 작업을 줄여 총 13260ms를 단축했습니다. 최적화 후 함수 시간 소비는 21720-13260=8460ms, 즉 8초가 됩니다.
여기서 질문이 있을 수 있습니다. 테이블의 구조에서 모든 th 및 td 요소는 tr 내에 있어야 하는데 1, 2, 5의 3단계 주기도 tr에 넣으면 어떨까요? 루프, 중첩 루프를 형성하면 더 빠르지 않을까요?
여기에서 이 작업이 수행되지 않는 두 가지 주요 이유는 다음과 같습니다.
첫째, 1, 2, 5를 어디에 배치하든 모든 th 및 td 요소에 대한 액세스 권한이 줄어들지 않습니다.
반면 선택기 $('th, td')는 sizzle의 getElementsByTagName 함수에 대한 두 번의 호출로 변환됩니다. 처음에는 모든 th를 가져오고 두 번째는 모든 td를 가져온 다음 수집합니다. 합병의 그들. getElementsByTagName은 내장 함수이기 때문에 이 함수는 루프가 없다고 볼 수 있다. 즉, 복잡도는 O(1)이다. 동일한 컬렉션의 병합은 연산인 Array의 관련 함수를 사용한다. 메모리에 있으며 복잡성도 O(1) 입니다.
반대로 선택기 $('th, 'td)가 tr 요소의 루프에서 사용되면 getElementsByTagName은 tr 요소에서 두 번 호출됩니다. 왜냐하면 어떤 요소에서 함수가 호출되는지에 관계없이 발생하기 때문입니다. , 함수 실행 시간은 동일하므로 tr을 반복할 때 사용하면 함수 호출이 119*2개 더 많아지고 효율성은 늘어나지 않고 감소합니다.
sizzle 선택기에 대한 기본 지식도 jQuery 코드 최적화에 도움이 되는 매우 중요한 측면임을 알 수 있습니다.
자바스크립트가 모든 것을 하도록 두지 마세요.
이전 기본 최적화에 따르면 시간이 21초에서 8초로 줄어들었지만 8초라는 숫자는 당연히 용납할 수 없는 수치입니다.
우리 코드에 대한 추가 분석에 따르면 실제로 루프 순회는 언어 수준에 있으며 속도가 상당히 빨라야 합니다. 각 요소에 대해 수행되는 작업은 jQuery에서 제공하는 기능으로 순회에 비해 대부분의 리소스를 차지합니다. 순회 중에 요소에 액세스하는 데 10ms가 걸리는 경우, 직설적으로 말하면 addClass를 실행하는 데 최소 100ms가 소요됩니다.
따라서 효율성을 더욱 최적화하려면 요소에 대한 작업을 줄이는 것부터 시작해야 합니다. 코드를 주의 깊게 검토한 결과, 이 함수의 스타일에 최소한 다음을 포함하여 많은 수정 사항이 있음을 발견했습니다.
Add class to all th.
모든 TD에 클래스를 추가하세요.
tr의 홀수 라인과 짝수 라인에 클래스를 추가하세요.
모든 th 및 td에 텍스트 정렬 스타일을 추가합니다.
사실 우리는 CSS 자체에 하위 항목 선택기가 있고 브라우저의 CSS 기본 구문 분석이 JavaScript가 요소에 클래스를 하나씩 추가하도록 하는 것보다 훨씬 더 효율적이라는 것을 알고 있습니다.
따라서 CSS를 제어할 수 있는 경우 이 함수에는 headerClass와 cellClass의 두 구성 항목이 없어야 하며 가능한 한 CSS에서 구성해야 합니다.
.beautiful-table th { /* 헤더 클래스의 내용*/ }
.beautiful -table td { /* content of cellClass*/ }
또한 tr의 홀짝수 행 스타일의 경우 n번째 자식 의사 클래스를 사용하여 일부 브라우저에서 구현할 수 있습니다. 관련하여, 이 의사 클래스를 지원하지 않는 브라우저에서만 addClass를 사용하여 기능 감지를 사용하여 스타일을 추가할 수 있습니다. 물론 IE 시리즈만을 최적화하고 싶다면 이 항목을 무시해도 됩니다.
n번째 하위 의사 클래스를 감지하려면 다음 아이디어를 사용할 수 있습니다. 스타일시트를 만든 다음 #testspan:nth-child(odd) {display:block과 같은 규칙을 만듭니다. ; 해당 HTML 구조, ID 테스트가 포함된 div를 만들고 그 안에 3개의 범위를 배치합니다.
DOM 트리에 스타일시트와 div를 추가합니다. 1번째와 3번째 스팬의 런타임 표시 스타일을 확인하세요. 블록인 경우 의사 클래스가 지원된다는 의미입니다. 생성한 스타일시트와 div를 삭제하고 프로브 결과를 캐시하는 것을 잊지 마세요. 마지막으로 모든 th 및 td 요소에 텍스트 정렬 스타일을 추가하는 것도 CSS를 통해 최적화할 수 있습니다. 어떤 정렬이 추가되는지 모르므로 몇 가지 스타일을 더 작성하세요.
/* CSS 스타일*/
.beautiful-table-center th,.beautiful-table-center td { text-align: center !important }
.beautiful- 테이블 오른쪽오른쪽 td { 텍스트 정렬: 오른쪽오른쪽 !중요 }
.beautiful-테이블-왼쪽 th,.beautiful-테이블-왼쪽 td { 텍스트 정렬: 왼쪽 !중요 }
/* javascript */
table.addClass('beautiful-table-' options.align)
물론 위에서 언급한 최적화는 CSS에 대한 제어를 기반으로 합니다. , CSS 스타일에 액세스할 수 없는 경우 어떻게 해야 합니까? 예를 들어 이것은 완전히 제어할 수 없는 제3자가 사용할 일반 플러그인 기능입니까? 완전히 불가능한 것은 아닙니다.
document.styleSheets와 같은 페이지에서 모든 CSS 규칙을 찾으세요. 모든 규칙을 순회하여 구성 항목에서 headerClass, cellClass 등을 꺼냅니다. 필요한 여러 클래스에서 모든 스타일을 추출한 다음 이를 beautiful-table th와 같은 새로운 선택기로 직접 조립합니다. 생성된 선택기를 사용하여 새 스타일시트를 생성하고 이를 DOM 트리에 추가합니다. 그런 다음 테이블에 beautiful-table 클래스를 추가하면 작업이 완료됩니다.
물론 위의 접근 방식은 실제로 시간이 많이 소요됩니다. 결국 스타일시트를 순회하여 스타일시트를 만들어야 합니다. 효율성을 높이는 데 큰 도움이 되는지 여부는 페이지 크기에 따라 달라지며, 기능 디자이너의 구체적인 요구 사항에 따라 다릅니다.
일반적으로 자바스크립트를 최대한 적게 실행하고 CSS에 더 많은 스타일링 작업을 전달하면 브라우저의 렌더링 엔진이 이를 완료하며, 이 기능은 addClass 및 CSS에 대한 호출에 대해 더욱 최적화될 수 있습니다. 100ms가 걸리므로 이 최적화는 원래의 120 726 = 846 작업을 직접 제거하고 84600ms의 시간을 절약합니다(물론 과장이지만 전체 기능의 소비 측면에서 이는 정말 큰 부분입니다).
이 기사에서는 jQuery의 다양한 구현 수준을 최적화하려고 할 뿐이며 jQuery의 전체 실행 프로세스에 대한 분석, 세부 소개 및 최적화 방향만 포함하며 일부 기본 최적화 방법에 대해서는 언급하지 않습니다. as: 먼저 DOM 트리에서 전체 테이블을 제거한 다음 다시 그리기를 줄이기 위해 모든 작업을 완료한 후 다시 DOM에 넣습니다. 올바른 이벤트 버블링 모델로 인해 발생하는 반복되는 이벤트 함수의 실행을 줄이기 위해 mouseover 및 mouseout을 mouseenter 및 mouseleave로 변경합니다. th 및 td와 같은 간단한 요소를 선택하려면 기본 getElementsByTagName을 사용하여 선택기를 분석하는 데 소요되는 시간을 줄이는 것이 우선순위입니다.
마지막으로 이 글에서는 프론트엔드 개발자들에게 비록 브라우저가 블랙박스일 수도 있지만, 이전에 어느 정도 이해할 수 있다면 많은 프레임워크, 도구, 라이브러리가 열려 있다는 점을 설명하고 싶습니다. 이를 사용하면 확실히 개인 기술을 향상시키고 최종 제품의 품질을 최적화하는 데 도움이 될 것입니다. "알지만 이유를 모른다"는 것은 매우 금기시되는 상황입니다.

JavaScript 프레임 워크의 힘은 개발 단순화, 사용자 경험 및 응용 프로그램 성능을 향상시키는 데 있습니다. 프레임 워크를 선택할 때 : 1. 프로젝트 규모와 복잡성, 2. 팀 경험, 3. 생태계 및 커뮤니티 지원.

서론 나는 당신이 이상하다는 것을 알고 있습니다. JavaScript, C 및 Browser는 정확히 무엇을해야합니까? 그들은 관련이없는 것처럼 보이지만 실제로는 현대 웹 개발에서 매우 중요한 역할을합니다. 오늘 우리는이 세 가지 사이의 밀접한 관계에 대해 논의 할 것입니다. 이 기사를 통해 브라우저에서 JavaScript가 어떻게 실행되는지, 브라우저 엔진의 C 역할 및 웹 페이지의 렌더링 및 상호 작용을 유도하기 위해 함께 작동하는 방법을 알게됩니다. 우리는 모두 JavaScript와 브라우저의 관계를 알고 있습니다. JavaScript는 프론트 엔드 개발의 핵심 언어입니다. 브라우저에서 직접 실행되므로 웹 페이지를 생생하고 흥미롭게 만듭니다. 왜 Javascr

Node.js는 크림 덕분에 효율적인 I/O에서 탁월합니다. 스트림은 메모리 오버로드를 피하고 큰 파일, 네트워크 작업 및 실시간 애플리케이션을위한 메모리 과부하를 피하기 위해 데이터를 점차적으로 처리합니다. 스트림을 TypeScript의 유형 안전과 결합하면 Powe가 생성됩니다

파이썬과 자바 스크립트 간의 성능과 효율성의 차이는 주로 다음과 같이 반영됩니다. 1) 해석 된 언어로서, 파이썬은 느리게 실행되지만 개발 효율이 높고 빠른 프로토 타입 개발에 적합합니다. 2) JavaScript는 브라우저의 단일 스레드로 제한되지만 멀티 스레딩 및 비동기 I/O는 Node.js의 성능을 향상시키는 데 사용될 수 있으며 실제 프로젝트에서는 이점이 있습니다.

JavaScript는 1995 년에 시작하여 Brandon Ike에 의해 만들어졌으며 언어를 C로 실현했습니다. 1.C Language는 JavaScript의 고성능 및 시스템 수준 프로그래밍 기능을 제공합니다. 2. JavaScript의 메모리 관리 및 성능 최적화는 C 언어에 의존합니다. 3. C 언어의 크로스 플랫폼 기능은 자바 스크립트가 다른 운영 체제에서 효율적으로 실행하는 데 도움이됩니다.

JavaScript는 브라우저 및 Node.js 환경에서 실행되며 JavaScript 엔진을 사용하여 코드를 구문 분석하고 실행합니다. 1) 구문 분석 단계에서 초록 구문 트리 (AST)를 생성합니다. 2) 컴파일 단계에서 AST를 바이트 코드 또는 기계 코드로 변환합니다. 3) 실행 단계에서 컴파일 된 코드를 실행하십시오.

Python 및 JavaScript의 미래 추세에는 다음이 포함됩니다. 1. Python은 과학 컴퓨팅 분야에서의 위치를 통합하고 AI, 2. JavaScript는 웹 기술의 개발을 촉진하고, 3. 교차 플랫폼 개발이 핫한 주제가되고 4. 성능 최적화가 중점을 둘 것입니다. 둘 다 해당 분야에서 응용 프로그램 시나리오를 계속 확장하고 성능이 더 많은 혁신을 일으킬 것입니다.

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.
