keydown 이벤트를 사용하는 경우 버튼을 길게 누르면 계속 실행됩니다. 이제는 꾹 눌러도 한 번만 구현하면 된다.
keydown의 실행 간격을 설정할 수 있나요? 특정 키를 누르고 있는 동안 400ms마다 실행될 수 있나요?
$(document).keydown(function(e){ //按下去就执行,按照事件类型来进行分类 var corelist = $('.corelist_item'); var readfloor = $('.J_read_floor'); if(corelist.length || readfloor.length){ if(e.keyCode == 87){ // w键 上一篇/楼 listJump(false,10,corelist); listJump(false,55,readfloor); } });
코드 작성/나도 피아노 치고 싶어/프런트 엔드는 그냥 제목/수집 이력서 keydown과 keyup은 한 쌍입니다. 페이지에서 허용하는 경우 한 번만 실행할 수 있는 jQuery의 one()을 사용하세요. 페이지를 새로 고치지 않으면 매개변수 추가가 다릅니다. keydown 버튼을 길게 누르면 이벤트가 하나만 발생하지만 버튼을 놓았다가 다시 누르면 keydown 이벤트가 계속 바인딩됩니다. 여기 여러분이 시도해 볼 수 있는 방법이 있습니다... 보기 흉하고 부정확하지만 JavaScript는 시간이 지나면 그 정도의 정확성을 달성할 수 없습니다. 위 내용은 jquery에서 일정 간격으로 keydown 이벤트를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
따라서 키업을 모니터링하면 키를 누르고 있을 때 발생하는 키다운을 제외할 수 있습니다.
예를 들어, 키업 중에 bool=true, bool=true를 설정하고, 키다운 중에 bool이 true인지 판단하고, true인 경우에만 실행한 다음 bool=false로 설정합니다.
매개변수로 판단하는 것 외에 한 번만 실행되는 jQuery의 one()을 사용할 수도 있습니다.$(btn).one("keydown",function(){
//dosomething
});
(function() {
var lock;
var interval = 400;
$(document).keydown(function() {
var date = new Date();
var time = date.getTime();
if (typeof lock == 'undefined') {
lock = time % interval;
}
if (Math.abs(lock - time % interval) < 13) {
console.log(date.getHours() + ':' + date.getMinutes() + ':' + date.getSeconds() + ':' + date.getMilliseconds());
//your code goes here!
}
}).keyup(function() {
lock = undefined;
});})();