onkeypress(keyboard键盘下载)
老铁们,大家好,相信还有很多朋友对于onkeypress和keyboard键盘下载的相关问题不太懂,没关系,今天就由我来为大家分享分享onkeypress以及keyboard键盘下载的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!
onkeydown、onkeyup和onkeypress三者之间的区别
onkeypress
这个事件在用户按下并放开任何字母数字键时发生。系统按钮(例如,箭头键和功能键)无法得到识别。
onkeyup
这个事件在用户放开任何先前按下的键盘键时发生。
onkeydown
这个事件在用户按下任何键盘键(包括系统按钮,如箭头键和功能键)时发生。
三者在事件的响应上还有一点不同,就是onkeydown、onkeypress事件响应的时候输入的字符并没有被系统接受,而响应onkeyup的时候,输入流已经被系统接受。
onkeyup,onkeydown和onkeypress的区别介绍
onkeyup,onkeydown和onkeypress的区别:
onkeypress
这个事件在用户按下并放开任何字母数字键时发生。系统按钮(例如,箭头键和功能键)无法得到识别。
onkeyup
这个事件在用户放开任何先前按下的键盘键时发生。
onkeydown
这个事件在用户按下任何键盘键(包括系统按钮,如箭头键和功能键)时发生。
测试发现onkeydown事件最先执行,其次是onkeypress,最后是onkeyup;onkeydown和onkeypress会影响onkeyup的执行。三个事件同事在的话,都是alert的话,只会弹出2个alert,up事件的alert不会弹出。
三者在事件的响应上还有一点不同,就是onkeydown、onkeypress事件响应的时候输入的字符并没有被系统接受,而响应onkeyup的时候,输入流已经被系统接受。由于onkeydown比onkeypress先执行,再根据上面的例子可以知道,onkeydown触发的时候输入流正要进入系统,也就是说onkeydown事件一完,输入流就进入了系统,无法改变。所以通过onkeydown事件可以改变用户是按了哪个键;而onkeypress事件则是在输入流进入系统后触发的,但输入流暂未被系统处理,此时已经不能改变输入流了;onkeyup则是输入流被系统处理后发生的。
希望对你有帮助
键盘事件keydown,keypress,keyup有哪些区别
按下键盘时会触发键盘事件,顺序为keydown-> keypress->keyup。
1、keydown、keypress事件触发在文字还没敲进文本框,这时如果在keydown、keypress事件中输出文本框中的文本,得到的是触发键盘事件前的文本,而keyup事件触发时整个键盘事件的操作已经完成,获得的是触发键盘事件后的文本。看下面这个例子:
复制代码代码示例:
<input id="input" value="default" type="text"/>
<script>
var input= document.getElementById('input');
input.onkeydown= function(){
console.log('onkeydown'+ this.value);
}
input.onkeypress= function(){
console.log('onkeypress'+ this.value);
}
input.onkeyup= function(){
console.log('onkeyup'+ this.value);
}
</script>
在文本框中敲入数字1,输出结果为:
onkeydown default
onkeypress default
onkeyup default1
2、keypress事件与keydown和keyup的主要区别
1)对中文输入法支持不好,无法响应中文输入
2)无法响应系统功能键(如delete,backspace)
3)由于前面两个限制,keyCode与keydown和keyup不是很一直
3、在keyup事件中无法阻止浏览器默认事件,因为在keypress时,浏览器默认行为已经完成,即将文字输入文本框(尽管这时还没显示),这个时候不管是preventDefault还是return false,都不能阻止在文本框中输入文字的行为,如要阻止在文本框中输入文字,必须在keydown或keypress时阻止。
看下面这个例子:
代码示例:
<input id="input" value="default" type="text"/>
<script>
var input= document.getElementById('input');
input.onkeydown= function(){
//return false;
console.log('onkeydown'+ this.value);
}
input.onkeypress= function(){
//return false;
console.log('onkeypress'+ this.value);
}
input.onkeyup= function(){
return false;
console.log('onkeyup'+ this.value);
}
</script>
结果为keydown、keypress事件中return false文本框无法输入文字,在keyup事件中return false文本框可以输入文字
4、textInput事件
文本框的键盘响应事件把textInpput也加进来,触发的顺序为:keydown-> keypress->textInput-> keyup
textInput事件是DOM3后支持的,主要用来替换keypress,与keypress的主要差别在于添加了对中文输入法的支持,还有一点就是textInput只在可编辑文本区才能触发(如input、textarea),而keypress是任何能获得焦点的控件的能触发(如button),但是textInput事件的支持还不是很好,目前只有safari、chrome支持。
好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!