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队列控制方法详解queue()/dequeue()/clearQueue()
Dec 02 Javascript
jquery判断浏览器类型的代码
Nov 05 Javascript
一个JavaScript操作元素定位元素的实例
Oct 29 Javascript
jQuery简单实现两级下拉菜单效果代码
Sep 15 Javascript
JS &amp; JQuery 动态添加 select option
Jun 08 Javascript
JS获取当前使用的浏览器名字以及版本号实现方法
Aug 19 Javascript
JavaScript中Array的实用操作技巧分享
Sep 11 Javascript
利用yarn实现一个webpack+react种子
Oct 25 Javascript
Node.js中process模块常用的属性和方法
Dec 13 Javascript
jquery操作select取值赋值与设置选中实例
Feb 28 Javascript
JS动态插入脚本和插入引用外部链接脚本的方法
May 21 Javascript
使用Vue开发自己的Chrome扩展程序过程详解
Jun 21 Javascript
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
php 分页函数multi() discuz
2009/06/21 PHP
PHP中文URL编解码(urlencode()rawurlencode()
2010/07/03 PHP
基于PHP的cURL快速入门教程 (小偷采集程序)
2011/06/02 PHP
php中把美国时间转为北京时间的自定义函数分享
2014/07/28 PHP
在Windows系统下使用PHP生成Word文档的教程
2015/07/03 PHP
PHP进行批量任务处理不超时的解决方法
2016/07/11 PHP
PHP目录操作实例总结
2016/09/27 PHP
JavaScript 页面坐标相关知识整理
2010/01/09 Javascript
Jquery index()方法 获取相应元素索引值
2012/10/12 Javascript
『JavaScript』限制Input只能输入数字实现思路及代码
2013/04/22 Javascript
javascript/jquery获取地址栏url参数的方法
2014/03/05 Javascript
js对图片base64编码字符串进行解码并输出图像示例
2014/03/17 Javascript
javascript中eval函数用法分析
2015/04/25 Javascript
使用JS代码实现点击按钮下载文件
2016/11/12 Javascript
Bootstrap基本样式学习笔记之标签(5)
2016/12/07 Javascript
基于javascript实现的购物商城商品倒计时实例
2016/12/11 Javascript
VueJS组件之间通过props交互及验证的方式
2017/09/04 Javascript
JavaScript编程设计模式之构造器模式实例分析
2017/10/25 Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
2017/12/27 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
详解微信小程序中组件通讯
2018/10/30 Javascript
在layui中layer弹出层点击事件无效的解决方法
2019/09/05 Javascript
JavaScript函数IIFE使用详解
2019/10/21 Javascript
vue动态合并单元格并添加小计合计功能示例
2020/11/26 Vue.js
微信小程序实现简单购物车功能
2020/12/30 Javascript
python中元类用法实例
2014/10/10 Python
Flask框架实现给视图函数增加装饰器操作示例
2018/07/16 Python
Python3使用Matplotlib 绘制精美的数学函数图形
2019/04/11 Python
详解KMP算法以及python如何实现
2020/09/18 Python
Luxplus瑞典:香水和美容护理折扣
2018/01/28 全球购物
Otticanet意大利:最顶尖的世界名牌眼镜, 能得到打折季的价格
2019/03/10 全球购物
网络研修随笔感言
2014/02/17 职场文书
作文评语大全
2014/04/23 职场文书
师德师风个人总结
2015/02/06 职场文书
详解如何使用Node.js实现热重载页面
2021/05/06 Javascript
python-opencv 中值滤波{cv2.medianBlur(src, ksize)}的用法
2021/06/05 Python