javascript attachmentEvent 바인딩 여러 이벤트 실행 순서 문제_javascript 기술
일반적인 바인딩 이벤트는
와 같은 페이지 요소에 직접 바인딩됩니다. 또 다른 방법은 이를 분리하여 js 코드로 작성하는 것입니다. 예를 들어 document.getElementById('wrap').onclick = function(){a();} 여러 메서드를 바인딩해야 하는 경우 document.getElementById('wrap').onclick =과 같이 직접 함께 작성하면 됩니다. function(){a();b();} 또는. 그러나 우리는 이와 같이 별도의 바인딩 메소드인 bin(el,name,fn)을 작성하는 경우가 많습니다.함수 바인딩(el,name,fn) { // 바인딩 이벤트
return el.addEventListener?el.addEventListener(name,fn,false):el.attachEvent('on' name,fn)
}
This
bind( document.getElementById('wrap'),'click',a)
bind(document.getElementById('wrap'),'click',b)
ie6,7에서는 8 이하에서는 실행 순서에 문제가 있을 것입니다(ie9 이하에서는 아직 명확하지 않습니다. 환경 테스트가 없습니다. 환경을 아는 친구들이 테스트하는 데 도움을 줄 수 있기를 바랍니다). 다른 브라우저는 ff, chrome, safari 순으로 실행됩니다. 정보를 검색한 결과 IE8에서는 실행 순서가 반대인 반면 IE6과 IE7은 무작위로 실행된다는 사실을 발견했습니다. IE가 어떻게 무작위로 실행되는지 정말 이해가 되지 않습니다. 혹시 숨은 동기가 있는 것은 아닐까? 이 작업의 목적을 아시는 분이 계시다면 제가 직접 테스트한 결과 ie8이 실행 순서를 바꾸는 반면 ie6과 7은 불규칙하게 실행되는 것으로 확인되었습니다. 무작위 실행은 실행될 때마다 순서가 달라야 한다는 점은 이해합니다. 그러나 실제로 작성할 때 순서가 고정되어 있는 한 실행 시의 순서도 고정됩니다. 규칙을 찾을 수 없습니다).
그러나 jQuery의 $.bind(type, data, fn) 메소드에는 이 문제가 없습니다. jQuery의 원본 코드를 살펴보니 이 코드도 사용되었습니다. 🎜>
elem.attachEvent("on" type, handler)
이 메소드로 이벤트가 바인딩되지만 그 전에는 jquery 객체가 이미 존재하는지 판단합니다. 동일한 유형의 핸들러가 있는 경우 반복적으로 바인딩되지 않지만 객체의 핸들이 핸들러에 병합되어 메소드가 됩니다. 이는 함수 c( ){a();b();} 이렇게 메소드를 입력하면 IE에서 여러 메소드를 바인딩할 때 실행 순서가 혼동되지 않습니다.
IE6 7은 무작위로 실행되나요? 지난번 테스트 해보니 순서가 거꾸로 된 것 같았고, 랜덤 실행 같은 것도 없었습니다.
특별히 테스트 하러 갔습니다
IE6에 대한 언급이 없습니다. 어떻게 테스트했는지 모르겠습니다.
작성자 답변:
귀하의 코드를 ie6 및 ie7에서 테스트했는데 실행 순서가 불규칙합니다. 정보 출처는 다음과 같습니다
저도 위의 소위 무작위 실행이 부적절하다고 생각합니다. 제 블로그 게시물에서 말했듯이 실행 순서는 불규칙하지만 실행 순서는 매번 동일합니다. 무작위라면 실행 순서가 매번 달라져야 한다는 점을 설명하고 싶습니다.

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

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

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...

엔트리 레벨 타입 스크립트 자습서를 마스터 한 후에는 TypeScript를 지원하고 JavaScript로 컴파일하는 IDE에서 자신의 코드를 작성할 수 있어야합니다. 이 튜토리얼은 TypeScript의 다양한 데이터 유형으로 뛰어납니다. JavaScript에는 NULL, UNDEFINED, BOOLEAN, 번호, 문자열, 기호 (ES6에 의해 소개 됨) 및 객체의 7 가지 데이터 유형이 있습니다. TypeScript는이 기반으로 더 많은 유형을 정의 하며이 튜토리얼은이 모든 튜토리얼을 자세히 다룹니다. 널 데이터 유형 JavaScript와 마찬가지로 Null in TypeScript
