JavaScript禁用右键单击优缺点分析


Posted in Javascript onJanuary 20, 2019

更有经验的用户很容易就能绕过禁用右键的问题,而访问大部分网页代码本身就是web浏览器的一个基本功能,根本不需要右键。

缺点

有很多方法可以绕过“没有右键脚本”,而实际上,这种脚本的唯一效果就是惹恼那些在web导航中合法使用右键上下文菜单(该菜单的正确名称)的访问者。

此外,我所看到的所有执行此操作的脚本都只阻止从鼠标右键访问上下文菜单。他们没有考虑到菜单也可以通过键盘访问这一事实。

所有人需要访问菜单使用104键键盘来选择屏幕上的对象,他们想要访问上下文菜单(例如由左点击它),然后按键盘上的上下文菜单中关键的立即左边的CTRL键在电脑键盘上。

在101键键盘上,您可以按住shift键并按下F10来执行右键单击命令。

JavaScript

如果您想要禁用web页面上的右键单击,这里有一个非常简单的JavaScript,您可以使用它来阻止对上下文菜单的所有访问(不仅是鼠标右键,还包括键盘)——这确实会惹恼您的访问者。

这个脚本甚至比大多数只阻塞鼠标按钮的脚本更简单,而且它在几乎所有浏览器中都能工作。

下面是完整的脚本:

<body oncontextmenu="return false;">

只是小段代码添加到web页面的body标签是更有效地阻止访问者的访问上下文菜单比许多no-right-click脚本,你可以在网上找到其他地方因为它阻止访问上述鼠标和键盘选项。

限制

当然,该脚本并不是在所有web浏览器中都能工作(例如,Opera会忽略它——但是Opera也会忽略所有其他不需要右键单击的脚本)。

此脚本也不会阻止访问者使用浏览器菜单中的View source选项访问页面源,或者阻止访问者保存web页面并在其喜爱的编辑器中查看已保存副本的源代码。

最后,尽管您可能禁用对上下文菜单的访问,但用户只需输入即可轻松地重新启用该访问

javascript:void oncontextmenu(null)

到浏览器的地址栏中。

总结:以上就是关于本次JS禁止右键的全部知识点内容,感谢大家对三水点靠木的支持。

Javascript 相关文章推荐
Jquery 获得服务器控件值的方法小结
May 11 Javascript
javascript学习笔记(十) js对象 继承
Jun 19 Javascript
jquery原创弹出层折叠效果点击折叠弹出一个层
Mar 12 Javascript
jQuery遍历json的方法分析
Apr 16 Javascript
JS实现pasteHTML兼容ie,firefox,chrome的方法
Jun 22 Javascript
jquery+css实现简单的图片轮播效果
Aug 07 jQuery
bootstrap paginator分页插件的两种使用方式实例详解
Nov 14 Javascript
垃圾回收器的相关知识点总结
May 13 Javascript
Vue父组件如何获取子组件中的变量
Jul 24 Javascript
vue element自定义表单验证请求后端接口验证
Dec 11 Javascript
JS实现“全选”和&quot;全不选&quot;功能代码实例
Feb 06 Javascript
jQuery中event.target和this的区别详解
Aug 13 jQuery
JavaScript中concat复制数组方法浅析
Jan 20 #Javascript
JavaScript中import用法总结
Jan 20 #Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
Jan 20 #Javascript
js序列化和反序列化的使用讲解
Jan 19 #Javascript
vue-router传参用法详解
Jan 19 #Javascript
vue-router实现嵌套路由的讲解
Jan 19 #Javascript
vue-router实现编程式导航的代码实例
Jan 19 #Javascript
You might like
使用 php4 加速 web 传输
2006/10/09 PHP
PHP多个文件上传到服务器实例
2014/10/29 PHP
PHP对文件进行加锁、解锁实例
2015/01/23 PHP
php使用number_format函数截取小数的方法分析
2016/05/27 PHP
php 变量引用与变量销毁机制详细介绍
2016/12/05 PHP
关于PHP中协程和阻塞的一些理解与思考
2017/08/11 PHP
jQuery focus和blur事件的应用详解
2014/01/26 Javascript
jQuery数据缓存用法分析
2015/02/20 Javascript
js实现拖拽效果(构造函数)
2015/12/14 Javascript
jQuery EasyUI Pagination实现分页的常用方法
2016/05/21 Javascript
代码详解javascript模块加载器
2018/03/04 Javascript
Vue props 单向数据流的实现
2018/11/06 Javascript
基于Vue实现图片在指定区域内移动的思路详解
2018/11/11 Javascript
微信小程序按钮点击动画效果的实现
2019/09/04 Javascript
js 获取扫码枪输入数据的方法
2020/06/10 Javascript
vue实现员工信息录入功能
2020/06/11 Javascript
实例讲解Python中SocketServer模块处理网络请求的用法
2016/06/28 Python
如何高效使用Python字典的方法详解
2017/08/31 Python
python虚拟环境的安装配置图文教程
2017/10/20 Python
Python可变参数*args和**kwargs用法实例小结
2018/04/27 Python
对python实现模板生成脚本的方法详解
2019/01/30 Python
详解python函数的闭包问题(内部函数与外部函数详述)
2019/05/17 Python
python lambda表达式在sort函数中的使用详解
2019/08/28 Python
python实现两个一维列表合并成一个二维列表
2019/12/02 Python
Python Selenium安装及环境配置的实现
2020/03/17 Python
纯css3实现走马灯效果
2014/12/26 HTML / CSS
影视动画专业个人的自我评价
2013/12/31 职场文书
精彩的广告词
2014/03/19 职场文书
校园文明标语
2014/06/13 职场文书
社区清明节活动总结
2014/07/04 职场文书
父亲节活动策划方案
2014/08/24 职场文书
领导干部作风建设剖析材料
2014/10/11 职场文书
2015毕业生实习期工作总结
2015/04/09 职场文书
班主任开场白
2015/06/01 职场文书
感恩教育观后感
2015/06/17 职场文书
2015年第31个教师节致辞
2015/07/31 职场文书