最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:41:59
文档

javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧

javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧:这里给出一段测试代码: document.onkeydown = function(){ document.getElementById(test).innerHTML += keydown; } document.onkeyup = function(){ document.getElementById(test).innerHTM
推荐度:
导读javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧:这里给出一段测试代码: document.onkeydown = function(){ document.getElementById(test).innerHTML += keydown; } document.onkeyup = function(){ document.getElementById(test).innerHTM


这里给出一段测试代码:
结果为:
keydown
keypress
keyup
显而易见,事件发生的顺序是: keydown --> keypress --> keyup
当按住一个键一段时间后再放开时,结果为:
keydown
keypress
keydown
keypress
keydown
keypress
keydown
keypress
...
keyup
n个keydown和n个keypress,1个keyup,系统设置的时间间隔.
关于click和dblclick
前段时间群里面的一个朋友问过一个关于click和dblclick的问题,在这里同时也整理一下,他的要求是click和dblclick有不同的事件处理程序,但是如果触发了dblclick则对click不做处理.如何解决?
我们先来看一下事件的发生情况,测试代码如下:


document.onclick = function(){
document.getElementById("test").innerHTML += "click
";
}
document.ondblclick = function(){
document.getElementById("test").innerHTML += "dblclick
";
}


双击时结果如下:
click
dblclick
当放慢点击速度时,结果如下:
click
click
click
可见,dblclick时,首先会触发一个click事件,然后如果在系统设置的双击延迟时间范围内有第二次click事件,则被认为是dblclick事件.
那么如何解决这位朋友提出的问题呢?给出代码如下:


function clickTest(){
document.getElementById("test").innerHTML += "click
";
}
function dblclickTest(){
document.getElementById("test").innerHTML += "dblclick
";
}
document.onclick = function(){
this.timeout = window.setTimeout(clickTest,300);
}
document.ondblclick = function(){
if(this.timeout)window.clearTimeout(this.timeout);
dblclickTest();
}


双击测试结果如下:
dblclick
dblclick
dblclick
dblclick

文档

javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧

javascriptonkeydown,onkeyup,onkeypress,onclick,ondblclick_javascript技巧:这里给出一段测试代码: document.onkeydown = function(){ document.getElementById(test).innerHTML += keydown; } document.onkeyup = function(){ document.getElementById(test).innerHTM
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top