前端禁用 页面复制粘贴

1、实现禁用 copy 事件的代码

java 复制代码
document.addEventListener('copy', function (event) {
    event.preventDefault(); // 阻止默认的复制行为
    alert(`复制功能已被禁用,无法复制此页面的内容。`);
});

事件监听器的工作原理

为了更好地理解这段代码的原理,我们可以更深入地分析 addEventListener() 的工作机制。

addEventListener() 方法允许我们为指定的事件类型添加一个监听器。这里,我们为 copy 事件添加了监听器,这意味着当用户尝试执行复制操作时,这个函数会被调用。

event.preventDefault() 是关键的部分,它告诉浏览器不要执行 copy 事件的默认行为。由于浏览器的默认行为是将选定的文本内容复制到剪贴板,所以 preventDefault() 可以阻止这一过程。

这种方法不仅可以应用于整个文档,也可以应用于特定的元素。如果我们只希望禁用某些特定部分的复制功能,而不是整个页面的内容,那么可以为特定元素添加 copy 事件监听器。例如:

java 复制代码
const protectedElement = document.getElementById('protected-content');
protectedElement.addEventListener('copy', function (event) {
    event.preventDefault();
    alert(`此内容受保护,无法复制。`);
});

2、增强版 (禁用右键菜单)

java 复制代码
document.addEventListener('contextmenu', function (event) {
    event.preventDefault();
    alert(`右键菜单已禁用。`);
});

3、示例

java 复制代码
document.addEventListener('copy', function (event) {
    event.preventDefault();
    alert(`复制功能已被禁用,无法复制此页面的内容。如需获得内容,请联系我们。`);
});

document.addEventListener('contextmenu', function (event) {
    event.preventDefault();
    alert(`右键菜单已被禁用,感谢您的理解。`);
});

// 提供替代的解决方案
document.querySelector('#request-content').addEventListener('click', function () {
    alert(`您可以通过填写申请表来获得此内容的复制权限。`);
});
相关推荐
有蝉几秒前
elementUI项目中,只弹一个【token过期提示】信息框的处理
前端·javascript·elementui
m0_7482449642 分钟前
使用Nginx正向代理让内网主机通过外网主机访问互联网
java·前端·nginx
几何心凉1 小时前
ToDesk云电脑、顺网云、网易云、易腾云、极云普惠云横测对比:探寻电竞最佳拍档
前端
yqcoder1 小时前
Node.js 与 JavaScript 是什么关系
开发语言·javascript·node.js
贵州晓智信息科技2 小时前
Three.js实现动态水泡效果逐步解析GLSL着色器
开发语言·javascript·着色器
老K(郭云开)2 小时前
最新版Edge浏览器加载ActiveX控件技术——allWebPlugin中间件之awp_CreateActiveXObject接口用法
前端·javascript·chrome·中间件·edge
一点一木3 小时前
从零开始:使用 Brain.js 创建你的第一个神经网络(一)
前端·javascript·人工智能
小璇玑学前端3 小时前
微信小程序地图,定位,仿多多自提点
前端
我的div丢了肿么办3 小时前
vue3.5的更新保证你看的明明白白
前端·javascript·vue.js
愚z3 小时前
WorkboxWebpackPlugin 使用指南
前端