IE浏览器只读输入框,按退格键返回上一页问题

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
	        }
	    }
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值