广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript如何屏蔽Backspace键
  • 254
分享到

JavaScript如何屏蔽Backspace键

2024-04-02 19:04:59 254人浏览 薄情痞子
摘要

小编给大家分享一下javascript如何屏蔽Backspace键,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!今天在IE浏览器

小编给大家分享一下javascript如何屏蔽Backspace键,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

今天在IE浏览器下发现,当把使用readonly="readonly"属性将文本框设置成只读<input type="text" readonly="readonly"/>时有一个奇怪的问题:如果光标进入只读文本框,然后按下Backspace键,就会跳转到上一个页面,效果就像点击了浏览器的后退按钮返回前一个页面一样,而在火狐和Google下没有这样的问题出现,为了解决这个问题,写了一个如下的处理方法,如果文本框是只读的,那么就禁用Backspace键。

代码如下:

 //处理键盘事件 禁止后退键(Backspace)密码或单行、多行文本框除外
   function banBackSpace(e){  
     var ev = e || window.event;//获取event对象  
     var obj = ev.target || ev.srcElement;//获取事件源  
     var t = obj.type || obj.getAttribute('type');//获取事件源类型 
     //获取作为判断条件的事件类型
     var vReadOnly = obj.getAttribute('readonly');
     //处理null值情况
     vReadOnly = (vReadOnly == "") ? false : vReadOnly;
     //当敲Backspace键时,事件源类型为密码或单行、多行文本的,
     //并且readonly属性为true或enabled属性为false的,则退格键失效
     var flag1=(ev.keyCode == 8 && (t=="passWord" || t=="text" || t=="textarea") 
           && vReadOnly=="readonly")?true:false;
     //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效
     var flag2=(ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea")
           ?true:false;    
     
     //判断
     if(flag2){
       return false;
     }
     if(flag1){  
       return false;  
     }  
   }
 window.onload=function(){
   //禁止后退键 作用于Firefox、Opera
   document.onkeypress=banBackSpace;
   //禁止后退键 作用于IE、Chrome
   document.onkeydown=banBackSpace;
 }

  加上这样的处理之后,就可以解决"只读输入框在IE下按下Backspace键回退到前一个页面的问题了"

ps:用JS屏蔽backspace(退格删除)键或某一个指定键的完美代码

当我们的网页内有一个只读属性的表单时,如下:

<input type="text" readonly="readonly" name="HuoShangName" id="HuoShangName" />

上面的这个文本域只是用来向用户展示一些信息的,用户不能对其进行更改,所以加上了“readonly='readonly'”的只读属性,但是在IE8下面,从外观上是看不出来它和其它正常文本域的区别的,所以有的用户可能会对其进行一些删除或者添加内容的一些操作,比如当光标位于这个只读属性的文本域内时,如果用户按下了backspace(退格删除键),那么就会导致整个浏览器的后退,会让人很是郁闷,这时我们要做的就是屏蔽这个只读文本域上的一些指定的键,使用户按下这些键时不会引起浏览器的退后,刷新,或者前进等动作。

<input class="input w350" type="text" readonly="readonly" onkeydown="PingBi('8')" name="HuoShangName" id="HuoShangName" />

上面的代码中,onkeydown表示的是当按下按键时的意思,下面来js函数pingbi的具体代码,也是非常简单的:

function PingBi(id){
 var k=window.event.keyCode;
 if(k==id){window.event.keyCode=0;window.event.returnValue=false;return false;}
}

好了,这样当光标位于只读属性的文本域内时,用户按下backspace(退格删除键)时就不会引起浏览器的后退了。

以上是“JavaScript如何屏蔽Backspace键”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网JavaScript频道!

--结束END--

本文标题: JavaScript如何屏蔽Backspace键

本文链接: https://www.lsjlt.com/news/72142.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript如何屏蔽Backspace键
    小编给大家分享一下JavaScript如何屏蔽Backspace键,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!今天在IE浏览器...
    99+
    2022-10-19
  • vbs如何屏蔽键盘按键
    这篇文章将为大家详细讲解有关vbs如何屏蔽键盘按键,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码如下:'code BY 伤脑筋 www.ntbak.cn ...
    99+
    2023-06-08
  • js如何屏蔽退格键
    这篇文章主要介绍了js如何屏蔽退格键,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。没有绝对的屏蔽,最好是js结合服务端混合用。服务端通过判断...
    99+
    2022-10-19
  • php如何屏蔽关键字
    这篇文章主要介绍“php如何屏蔽关键字”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php如何屏蔽关键字”文章能帮助大家解决问题。方法一:使用PHP内置的函数PHP内置了函数来处理字符串、正则表达式...
    99+
    2023-07-05
  • 如何实现右键菜单屏蔽和复制到剪贴板的javascript
    这篇文章主要介绍了如何实现右键菜单屏蔽和复制到剪贴板的javascript,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。function copyText(){  ...
    99+
    2023-06-03
  • 批处理如何实现网站屏蔽与解除屏蔽
    这篇文章主要为大家展示了“批处理如何实现网站屏蔽与解除屏蔽”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“批处理如何实现网站屏蔽与解除屏蔽”这篇文章吧。@echo off&col...
    99+
    2023-06-09
  • vps如何屏蔽域名
    要屏蔽某个域名,您可以在VPS上进行如下操作:1. 编辑`/etc/hosts`文件:通过编辑`/etc/hosts`文件,您可以将...
    99+
    2023-08-20
    vps
  • vbs如何屏蔽端口
    这篇文章主要介绍了vbs如何屏蔽端口,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。复制代码 代码如下:'On Error Resume Next Const ALLO...
    99+
    2023-06-08
  • 如何编写屏蔽up键禁止游戏运行脚本
    本篇内容介绍了“如何编写屏蔽up键禁止游戏运行脚本”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!增强版,先判断游戏是否运行,如果是游戏第一次...
    99+
    2023-06-08
  • win7如何屏蔽usb接口
    今天小编给大家分享一下win7如何屏蔽usb接口的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。按win+r进入运行窗口,输入...
    99+
    2023-06-28
  • PHP中如何屏蔽错误
    这篇文章主要介绍了PHP中如何屏蔽错误,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、@屏蔽法@在php中一个抑制错误的符号,即便是你开启了报错功能,只要在错误语句之前加上...
    99+
    2023-06-15
  • Rsync 如何屏蔽某些目录
    这篇文章主要介绍“Rsync 如何屏蔽某些目录”,在日常操作中,相信很多人在Rsync 如何屏蔽某些目录问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Rsync 如何屏蔽某些目录”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-09
  • 虚拟主机如何屏蔽ip
    在虚拟主机中屏蔽ip的方法:1.远程登录虚拟主机;2.进入iis管理器;3.选择站点进入属性页面;4.“编辑”ip地址和域名限制;5.添加屏蔽的ip,确认;具体步骤如下:首先,远程登录虚拟主机,进入虚拟主机器操作界面;进入到虚拟主机器操作界...
    99+
    2022-10-21
  • php如何屏蔽程序错误
    这篇文章主要介绍了php如何屏蔽程序错误,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php屏蔽程序错误的方法:首先打开php配置文件php.ini;然后在配置文件中找到【d...
    99+
    2023-06-15
  • windows硬盘坏道如何屏蔽
    本篇内容介绍了“windows硬盘坏道如何屏蔽”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!硬盘坏道屏蔽方法 :首先大家需要使用“diskg...
    99+
    2023-07-02
  • 如何屏蔽QQ启动扫描
    解决办法:批处理加开机启动项: @echo off md %temp%\QQSC.execho y|cacls %temp%\QQSC.exe  /d everyone exit 做个批处理在启动项目就干掉...
    99+
    2023-05-23
  • html5 video标签如何屏蔽右键视频另存为的js代码
    这篇文章将为大家详细讲解有关html5 video标签如何屏蔽右键视频另存为的js代码,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 ...
    99+
    2022-10-19
  • 如何突破网站对selenium的屏蔽
    这篇文章主要介绍如何突破网站对selenium的屏蔽,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!使用selenium模拟浏览器进行数据抓取无疑是当下最通用的数据采集方案,它通吃各种数据加载方式,能够绕过客户JS加密...
    99+
    2023-06-02
  • win7如何屏蔽网页弹窗广告
    这篇文章主要讲解了“win7如何屏蔽网页弹窗广告”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“win7如何屏蔽网页弹窗广告”吧!打开浏览器,点击设置按钮,选择Internet选项。在窗口中选...
    99+
    2023-06-28
  • 如何解决Godaddy域名解析被屏蔽但IP地址并没有屏蔽掉的问题
    如何解决Godaddy域名解析被屏蔽但IP地址并没有屏蔽掉的问题,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。继前几天Google服务抽风无法访问后,我们伟大的墙,终于看上我这...
    99+
    2023-06-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作