javascript - 關(guān)于禁用文本選擇與復(fù)制的問題
問題描述
樣式如下.test1 { user-select: none;}html 結(jié)構(gòu)如下
<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>
給其中的某幾項(xiàng)做了禁用本文選擇,單獨(dú)對(duì)某一項(xiàng)選擇時(shí),確實(shí)能夠禁用選擇,其中的內(nèi)容也無法復(fù)制,但是如果用cmd + a 進(jìn)行全選時(shí),會(huì)看到被禁用的項(xiàng)在頁(yè)面上顯示的是沒有被選擇,但此時(shí)內(nèi)容能被復(fù)制下來。
接下來用 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);});
發(fā)現(xiàn)還是會(huì)在單獨(dú)選取時(shí)生效,但全部選取時(shí)就失敗了,所以想問下有什么辦法能夠在可選取的節(jié)點(diǎn)中穿插不可選取的節(jié)點(diǎn),還能使得全選復(fù)制時(shí)只選取到可選取的內(nèi)容。
問題解答
回答1:可以換種思路,比如把文本放到css中。css中的文本就完全無法選中和復(fù)制了。隨手寫了個(gè)測(cè)試代碼:
JsFiddle: https://jsfiddle.net/d95cugaL/
JsBin: http://jsbin.com/nowoxuceta/e...
或者再進(jìn)一步,直接把文本放在圖片上...
回答2:這兒有個(gè)思路,就是你可以禁止ctrl+c的鼠標(biāo)事件。//禁止ctrl復(fù)制
document.onkeydown=function(){ if((event.ctrlKey) && (window.event.keycode==67)){ event.returnValue=false; alert('Ctrl+C被禁止啦!'); }}
如果全選有問題,也可以禁止ctrl+A
相關(guān)文章:
1. 我的html頁(yè)面一提交,網(wǎng)頁(yè)便顯示出了我的php代碼,求問是什么原因?2. tp6表單令牌3. docker 17.03 怎么配置 registry mirror ?4. java 排序的問題5. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?6. django - 后臺(tái)返回的json數(shù)據(jù)經(jīng)過Base64加密,獲取時(shí)用python如何解密~!7. node.js - node 客戶端socket一直報(bào)錯(cuò)Error: read ECONNRESET,用php的socket沒問題哈。。8. 數(shù)據(jù)庫(kù) - 使用讀寫分離后, MySQL主從復(fù)制延遲會(huì)導(dǎo)致讀不到數(shù)據(jù)嗎?9. 老哥們求助啊10. javascript - canvas 可以實(shí)現(xiàn) PS 魔法橡皮擦的功能嗎?
