IE浏览器只读输入框,按退格键返回上一页问题
问题描述
在vue+element-ui开发时,使用到el-input的readonly属性,在ie11浏览器下点击输入框仍然能获取到焦点。这个时候按退格键(backspace)会使得url地址栏的地址回退上一页。
问题分析
ie浏览器退格键是返回上一页的快捷键。在输入状态时,退格键的返回上一页会被屏蔽。但是在只读输入框中,能获取到焦点,又没有对退格键的点击事件进行处理。就会触发返回上一页。
解决方案
根据需要,可以屏蔽在不同情况下,返回上一页的按钮事件。添加如下代码,在mounted代码块中运行。
mounted () {
document.onkeydown = function (e) {
var ev = e || window.event // 获取event对象
var obj = ev.target || ev.srcElement // 获取事件源
var readOnly = obj.readOnly || obj.getAttribute('readonly')
if (ev.keyCode === 8) { // 等于8则是退格键被按下
if (condition) { // 在这里可以对屏蔽条件进行进一步限制
return false
}
}
}
}