크로스 도메인 iframe 및 부모 요소 이벤트 캡처 : Mousedown 이벤트의 제한 및 응답 전략 이해
소개 : Iframe이 부모 인 Mousedown 이벤트 캡처에 미치는 영향
웹 개발에서 우리는 종종 Mousedown과 같은 DOM 요소의 이벤트를 들어야합니다. 그러나 DIV 요소에 내부에 iframe 하위 요소가 포함 된 경우, 특히 마우스가 IFRAME 영역을 클릭 할 때 부모 DIV의 마우스 다운 이벤트를 트리거 할 수 없다는 것을 알 수 있습니다. 이는 일반적으로 이벤트가 Dom Tree를 따라 거품이 발생하기 때문에 개발자에게 혼란을 초래합니다.
다음 HTML 구조 및 JavaScript 코드를 고려하십시오.
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"> </script> <div class="테스트 테스트 링크"> <a href="/"> 테스트 링크 </a> </div> <div class="테스트 테스트 -Iframe"> <iframe src="https://www.google.com/" style="너비 : 100%; 높이 : 200px; 국경;"> </iframe> </div> <cript> jQuery ( ". test"). on ( "Mousedown", () => console.log ( "Test Mousedown 이벤트 트리거")); 스크립트></cript>
Test-Link Div 내부의 요소가 클릭되면 Console.log ( "Test Mousedown 이벤트 트리거")가 정상적으로 실행됩니다. 그러나 DIV 내부의
핵심 원칙 : 상 동성 정책과 iframes 간의 이벤트 격리
위의 현상을 이해하려면 브라우저의 두 가지 핵심 보안 메커니즘 인 동일한 오리핀 정책 (SOP)과 iframe의 샌드 박스 기능에 대한 심층적 인 이해가 필요합니다.
동일한 원산지 정책 (SOP) : 동일한 오리핀 정책은 브라우저의 가장 핵심 보안 메커니즘 중 하나입니다. 다른 소스의 문서 나 스크립트를 통해 서로의 자원에 대한 액세스를 제한합니다. 두 URL의 프로토콜, 도메인 이름 및 포트가 동일하면 상 동성으로 간주됩니다. 다른 출처의 문서는 일반적으로 서로의 DOM을 읽거나 수정할 수 없으며 서로의 사건을 직접들을 수 없습니다.
Iframe의 이벤트 격리 : iframe 요소는 현재 문서에 또 다른 독립적 인 브라우징 컨텍스트를 포함합니다. 즉, iFrame 내부에로드 된 컨텐츠에는 자체 문서 객체 모델 (DOM), 자체 전역 창 객체 및 자체 이벤트 처리 메커니즘이 있음을 의미합니다. 마우스 이벤트가 iframe 영역 내에서 발생하면 브라우저는 이벤트의 대상을 부모 문서의 iframe 요소 자체가 아닌 iframe 내부의 문서 또는 요소로 인식하며 부모 Div가 아닙니다. 동일한 오리핀 정책의 한계로 인해 iframe에 의해로드 된 내용이 상위 페이지에 상 동성이 아닌 경우 (예 : SRC = "https://www.google.com/"), 부모 문서의 JavaScript는 iframe 내부의 DOM에 액세스 할 수 없으며 그 내부의 이벤트에 대해들을 수 없습니다. 따라서 이벤트는 IFRAME의 독립적 인 맥락에서 처리되며 부모 Div에 거품이되지 않습니다.
요컨대, iframe은 독립형 미니 브라우저 창과 같으며 내부에서 발생하는 모든 것은 크로스 도메인 케이스에서 외부 부모 페이지에 보이지 않으며 직접 개입 할 수 없습니다.
샘플 코드 분석
제공된 예에서 :
- jquery ( ". test"). on ( "Mousedown", ...)이 코드는 테스트 클래스의 모든 요소에 대한 Mousedown 이벤트를 바인딩하려고합니다.
위 내용은 크로스 도메인 iframe 및 부모 요소 이벤트 캡처 : Mousedown 이벤트의 제한 및 응답 전략 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Stock Market GPT
더 현명한 결정을 위한 AI 기반 투자 연구

인기 기사

뜨거운 도구

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

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

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

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

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

이 튜토리얼은 R Language Rvest 패키지를 사용하여 웹 페이지에서 URL을 크롤링 할 때 JavaScript가 컨텐츠를 동적으로로드하는 경우 실패 실패 문제를 탐색합니다. 이 기사는 기존의 HTML 구문 분석 방법이 유효하지 않은 이유를 자세히 설명하고 효율적인 솔루션을 제공합니다. 웹 페이지 뒤에있는 API 인터페이스를 식별하고 직접 호출하여 HTTR 패키지를 사용하여 JSON 데이터를 얻으므로 필요한 정보를 성공적으로 추출합니다.

HTML 양식 요소를 비활성화하려면 비활성화 된 속성을 사용할 수 있습니다.이 속성은 사용자 상호 작용을 방지 할 수 있으며 요소 값은 양식으로 제출되지 않습니다. 이 속성은 부울 유형이며 입력, TextArea, Select 또는 버튼과 같은 요소 태그를 형성하기 위해 직접 추가 할 수 있습니다. 예를 들어 Document.GetElementById ( "myInput")와 같은 JavaScript를 통해 동적으로 제어 할 수도 있습니다. disabled = true. 요소를 편집 할 수 없지만 값이 여전히 제출 된 경우 readonly 속성을 사용해야합니다. 장애인 속성은 간단하고 효과적이며 널리 지원됩니다.

TolinktoAspeCificPartOfApageUsingAnchorsinhtml, antardauniqueIdToThetArgetElement, suchAS, thencreateAhyperLinkwithHref = "#section1"toscrolltothatsection 및 forcross-pageLinking, usethefullurllikepage.html#section1, ensuringsmml#

HTML 버튼을 만들고 클릭 이벤트를 설정하여 JavaScript 함수를 호출하십시오. 2. CSS를 사용하여 버튼을 페이지의 오른쪽 하단에 고정하고 숨겨진 기본 상태를 설정하십시오. 3. JavaScript를 통해 스크롤 이벤트를 듣고 스크롤 거리가 300px를 초과 할 때 버튼을 표시하고 클릭하면 상단에 매끄럽게 스크롤하십시오. 마지막으로, 사용자 경험을 향상시키기 위해 상단 버튼으로 돌아가고 HTML, CSS 및 JavaScript와의 공동으로 전체 기능이 완료됩니다.

TheActionAttributesPecifiesWheretOsendtheFormData, andthemethodattributedEfineshowTosendItshttpMethods.1.TheActionAttributesetSthedEstinationUrl (절대적 상관 관계); Ifoms, formsubmitStotheCurrentPage.2

accept = "image/*"만 허용 이미지, accept = ". pdf"pdf, accept = ". doc, .docx, .pdf, .txt"와 같은 HTML 파일의 업로드 유형을 제한하기 위해 수락 속성을 사용하여 HTML 파일을 허용합니다. 다르며 서버 검증을 대체하는 대신 가용성을 향상시키는 데만 사용됩니다.

이 기사에서는 CSS를 사용하여 콘텐츠에서 투명하고 부유 한 맞춤형 스크롤 막대를 달성하는 방법에 대해 자세히 설명합니다. 오버플로를 결합하여 : 오버레이; 다른 브라우저 (WebKit/Firefox)의 속성 및 스크롤바 유사 요소 스타일 (WebKit/Firefox)은 스크롤 바의 색상, 투명성, 너비 및 둥근 모서리를 정확하게 제어하여 웹 인터페이스의 시각적 일관성 및 사용자 경험을 향상시킬 수 있습니다.

이를 사용하여 숫자 및 단위 브랜치의 표시를 방지하는 것과 같은 HTML에서 라인 브레이크 공간을 만듭니다. 1. 이름, 값 및 단위 사이의 선을 깨지 않도록하는 데 사용됩니다. 2. 줄 내에서 텍스트 형식을 유지하십시오. 3. 빈 자리 표시 자로 사용할 수 있지만 CSS를 권장합니다. 등 등과 같은 다른 공간 문자는 특별한 시나리오에 적합하지만 대부분의 경우 충분합니다. 레이아웃을 남용하지 않도록주의하십시오. 대신 CSS를 사용해야하며, 다중은 병합되지 않으며 화면 리더는 정상적으로 인식 할 수 있으므로 텍스트가 일관되게 표시되도록 합리적으로 사용해야합니다.
