IE下用react添加keydown事件 backspace按键会导致页面回退

先描述下出现问题的场景,使用react在组件componentDidMount时添加监听事件 window.addEventListener('keydown', this.handleKeyDown);当组件销毁时移除这个监听事件。
键盘事件处理是在input框聚焦时,判断是否按下了“backspace”键时,如果这个input框内有值,则会先删除,当没有值时,继续按下“backspace”,将会执行某个函数,贴出如下代码:

https://img2.mukewang.com/5c7f2aa10001504a06750492.jpg

按下“backspace”后里面执行的这个函数的作用在这里和我要问的问题没什么太大关系,我就不详细说了;接下来问题来了,按下了“backspace”后,先是把input内的值删除了,在谷歌、火狐等浏览器里没有值以后会执行这里面的函数,不会有其他操作;然后到了IE里面,这个input框没有值的时候,然后再按一下就会把页面给回退了,这里面的函数执行了也看不到。

求大神们有没有什么方法可以阻止IE页面回退。

第一次提问题,如果大家觉得问题描述不够清楚可以留言继续问我,我尽量解释解释。
烦请各位大神多多指导~谢谢!!


慕妹3146593
浏览 528回答 1
1回答

慕尼黑5688855

问题解决了,我在处理backspace的时候,加阻止冒泡,同时返回false来禁止执行,重点是这个false来起作用。。。结果就好了,,,了。。。。。。。这样就把IE默认自带的回退按键禁止了。。。更新代码如下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)            }if (this.autoComplete.isEmpty() && e.keyCode === KeyCodeMap.BACK_SPACE) {                e.preventDefault()                e.stopPropagation()                return false            }            break        case KeyCodeMap.LEFT:            XXXXXXX            XXXXXXX            break        case KeyCodeMap.RIGHT:            XXXXXXX            XXXXXXX            break        default:            break        }    }}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript