js禁止复制页面文字
做项目的时候有客户提出要求,不能用用户浏览他发表的文章时复制他的文章,一种比较简单的方法,禁止用户选中页面的文字和禁止用户右键菜单:
document.oncontextmenu = new Function("event.returnValue=false");
document.onselectstart = new Function("event.returnValue=false");如果只是禁止部分区域的话,直接在标签上加上onselectstart=“return false”
<div onselectstart="return false" id="div" >
此区域禁止复制
</div>或者
<div onselectstart="return false" id="div" >
此区域禁止复制
</div>
<script type="text/javascript" >
$(document).ready(function(){
document.getElementById('div').onselectstart =function(){
return false;
};
});
</script>在火狐下这种js写法是无效的,在火狐下有个屏蔽选择样式的样式属性 -moz-user-select (只支持火狐浏览器)
<div style="-moz-user-select:none;" >
禁止复制此区域
</div>如果要禁止整个页面
<script type="text/javascript" >
$(document).ready(function(){
$("body").css("-moz-user-select","none");
});
</script>-moz-user-select主要有三个值 none -moz-all -moz-none
| Input表单中文字 | 一般页面文字 | |
| none | 不可选 | 不可选 |
| -moz-all | 不可选 | 可选 |
| -moz-none | 可选 | 不可选 |
本文内容仅供个人学习/研究/参考使用,不构成任何决策建议或专业指导。分享/转载时请标明原文来源,同时请勿将内容用于商业售卖、虚假宣传等非学习用途哦~感谢您的理解与支持!