>웹 프론트엔드 >JS 튜토리얼 >jquery에서 일정 간격으로 keydown 이벤트를 실행하는 방법은 무엇입니까?

jquery에서 일정 간격으로 keydown 이벤트를 실행하는 방법은 무엇입니까?

黄舟
黄舟원래의
2017-06-27 13:47:402066검색

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은 한 쌍입니다.
따라서 키업을 모니터링하면 키를 누르고 있을 때 발생하는 키다운을 제외할 수 있습니다.
예를 들어, 키업 중에 bool=true, bool=true를 설정하고, 키다운 중에 bool이 true인지 판단하고, true인 경우에만 실행한 다음 bool=false로 설정합니다.

페이지에서 허용하는 경우
매개변수로 판단하는 것 외에 한 번만 실행되는 jQuery의 one()을 사용할 수도 있습니다.

$(btn).one("keydown",function(){
//dosomething
});

한 번만 실행할 수 있는 jQuery의 one()을 사용하세요. 페이지를 새로 고치지 않으면 매개변수 추가가 다릅니다. keydown 버튼을 길게 누르면 이벤트가 하나만 발생하지만 버튼을 놓았다가 다시 누르면 keydown 이벤트가 계속 바인딩됩니다.

여기 여러분이 시도해 볼 수 있는 방법이 있습니다... 보기 흉하고 부정확하지만 JavaScript는 시간이 지나면 그 정도의 정확성을 달성할 수 없습니다.

(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() + &#39;:&#39; + date.getMinutes() + &#39;:&#39; + date.getSeconds() + &#39;:&#39; + date.getMilliseconds());
			//your code goes here!
		}
	}).keyup(function() {
		lock = undefined;
	});})();

위 내용은 jquery에서 일정 간격으로 keydown 이벤트를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.