input의blur 이벤트는div를 숨기고,div의onclick 이벤트는 해결 방안이 적용되지 않습니다
3156 단어 html
질문: 목록을 눌렀을 때 목록의 클릭 이벤트를 터치하지 않나요?
<input type="text" name="" onfocus="show()" onblur="hide()" />
// input test div
<div id="test" onclick="clickThis()">testdiv>
<script>
var div = document.getElementById("test");
function show(){
div.style.display="block"
}
function hide(){
div.style.display="none"
}
function clickThis(){
alert(div)
}
script>
html>
원인: 목록을 눌렀을 때 input의blur 이벤트를 촉발한 것과 같습니다. 목록은 숨겨지고 이벤트를 눌렀을 때 효력이 발생하지 않습니다.
솔루션은 다음과 같습니다.
1. blur의 리셋 함수에 타이머를 추가하여 blur 리셋 함수의 실행 시간을 지연시킨다. 그러면 div를 눌렀을 때 input의 blur 행위가 먼저 터치되지만 타이머 지연이 추가되었기 때문에div의 click 리셋이 실행된 후에야 input의 blur 행위의 리셋을 실행할 수 있다.
코드:
function hide(){
setTimeout(function(){
div.style.display="none"
},300)}
}
2. div의 클릭 이벤트를 mousedown 이벤트로 변경합니다. 왜냐하면 mousedown 행위는 마우스가 눌렸을 때 터치되고 클릭 행위는 마우스가 눌렸을 때 다시 들어올릴 때 터치되기 때문입니다.
코드:
<div id="test" onmousedown="clickThis()">testdiv>
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다른 사람의 웹사이트 편집: contenteditable 및 designMode그래도 우리가 그렇게 할 수 있다고 생각하는 것은 멋진 일입니다. 제가 강조하고 싶었던 일종의 관련 API가 실제로 몇 개 있기 때문에 오늘 그것을 가져왔습니다. contenteditable는 "true" 값이 할당...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.