IE下用react添加keydown事件 backspace按键会导致页面回退
先描述下出现问题的场景,使用react在组件componentDidMount时添加监听事件 window.addEventListener('keydown', this.handleKeyDown);当组件销毁时移除这个监听事件。
键盘事件处理是在input框聚焦时,判断是否按下了“backspace”键时,如果这个input框内有值,则会先删除,当没有值时,继续按下“backspace”,将会执行某个函数,贴出如下代码:
handleKeyDown (e) {
if (document.activeElement.className === 'search-input') {
let cursorPosition = this.props.cursorPosition
switch (e.keyCode) {
case KeyCodeMap.BACK_SPACE:
case KeyCodeMap.DELETE:
if (this.autoComplete.isEmpty() && cursorPosition >= 0) {
this.props.onHandleDeleteSelect(cursorPosition)
}
break
case KeyCodeMap.LEFT:
XXXXXXX
XXXXXXX
break
case KeyCodeMap.RIGHT:
XXXXXXX
XXXXXXX
break
default:
break
}
}
}
按下“backspace”后里面执行的这个函数的作用在这里和我要问的问题没什么太大关系,我就不详细说了;接下来问题来了,按下了“backspace”后,先是把input内的值删除了,在谷歌、火狐等浏览器里没有值以后会执行这里面的函数,不会有其他操作;然后到了IE里面,这个input框没有值的时候,然后再按一下就会把页面给回退了,这里面的函数执行了也看不到。
求大神们有没有什么方法可以阻止IE页面回退。
第一次提问题,如果大家觉得问题描述不够清楚可以留言继续问我,我尽量解释解释。
烦请各位大神多多指导~谢谢!!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
问题解决了,我在处理backspace的时候,加阻止冒泡,同时返回false来禁止执行,重点是这个false来起作用。。。结果就好了,,,了。。。。。。。
这样就把IE默认自带的回退按键禁止了。。。
更新代码如下
handleKeyDown (e) {
if (this.autoComplete.isEmpty() && e.keyCode === KeyCodeMap.BACK_SPACE) {
可能是要停止原生事件的冒泡吧,IE和其他浏览器的事件处理模型是不一样的