最新文章专题视频专题问答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
当前位置: 首页 - 科技 - 知识百科 - 正文

jQuery键盘事件keydown与keypress的区别详解

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

jQuery键盘事件keydown与keypress的区别详解

jQuery键盘事件keydown与keypress的区别详解:按下键盘时会触发键盘事件,顺序为keydown -> keypress ->keyup。1、keydown、keypress事件触发在文字还没敲进文本框,这时如果在keydown、keypress事件中输出文本框中的文本,得到的是触发键盘事件前的文本,而keyup事件触发时整个键盘事件的操作
推荐度:
导读jQuery键盘事件keydown与keypress的区别详解:按下键盘时会触发键盘事件,顺序为keydown -> keypress ->keyup。1、keydown、keypress事件触发在文字还没敲进文本框,这时如果在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支持。

文档

jQuery键盘事件keydown与keypress的区别详解

jQuery键盘事件keydown与keypress的区别详解:按下键盘时会触发键盘事件,顺序为keydown -> keypress ->keyup。1、keydown、keypress事件触发在文字还没敲进文本框,这时如果在keydown、keypress事件中输出文本框中的文本,得到的是触发键盘事件前的文本,而keyup事件触发时整个键盘事件的操作
推荐度:
标签: 键盘 区别 小键盘
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top