javascript - 关于禁用文本选择与复制的问题
问题描述
样式如下.test1 { user-select: none;}html 结构如下
<body><p class='content'> <p class='test2'>111</p> <p class='test1'>222</p> <p class='test2'>333</p> <p class='test1'>444</p> <p class='test2'>555</p></p></body>
给其中的某几项做了禁用本文选择,单独对某一项选择时,确实能够禁用选择,其中的内容也无法复制,但是如果用cmd + a 进行全选时,会看到被禁用的项在页面上显示的是没有被选择,但此时内容能被复制下来。
接下来用 js 去控制:[].forEach.call(document.querySelectorAll(’.test1’), (node) => { node.addEventListener(’copy’, (e) => { e.stopPropagation(); e.preventDefault(); console.log(1); return false; }, true); node.addEventListener(’selectstart’, (e) => { e.stopPropagation(); e.preventDefault(); console.log(2); return false; }, true);});
发现还是会在单独选取时生效,但全部选取时就失败了,所以想问下有什么办法能够在可选取的节点中穿插不可选取的节点,还能使得全选复制时只选取到可选取的内容。
问题解答
回答1:可以换种思路,比如把文本放到css中。css中的文本就完全无法选中和复制了。随手写了个测试代码:
JsFiddle: https://jsfiddle.net/d95cugaL/
JsBin: http://jsbin.com/nowoxuceta/e...
或者再进一步,直接把文本放在图片上...
回答2:这儿有个思路,就是你可以禁止ctrl+c的鼠标事件。//禁止ctrl复制
document.onkeydown=function(){ if((event.ctrlKey) && (window.event.keycode==67)){ event.returnValue=false; alert('Ctrl+C被禁止啦!'); }}
如果全选有问题,也可以禁止ctrl+A
相关文章:
1. javascript - setIndex的作用2. java - 对于jsp技术,aspx技术的困惑3. javascript - [,null]是什么用法4. java - idea如何不显示.idea target这些文件夹5. docker - dcoker gitlab 如何修改主机地址?6. apache - 想把之前写的单机版 windows 软件改成网络版,让每个用户可以注册并登录。类似 qq 的登陆,怎么架设服务器呢?7. node.js - electron使用原生node模块8. java - log4j和slf4j 【配置有知道的么】9. dockerfile - [docker build image失败- npm install]10. docker内创建jenkins访问另一个容器下的服务器问题
