javascript - 關(guān)于禁用文本選擇與復(fù)制的問(wèn)題
問(wèn)題描述
樣式如下.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)容也無(wú)法復(fù)制,但是如果用cmd + a 進(jìn)行全選時(shí),會(huì)看到被禁用的項(xiàng)在頁(yè)面上顯示的是沒(méi)有被選擇,但此時(shí)內(nèi)容能被復(fù)制下來(lái)。
接下來(lái)用 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í)就失敗了,所以想問(wèn)下有什么辦法能夠在可選取的節(jié)點(diǎn)中穿插不可選取的節(jié)點(diǎn),還能使得全選復(fù)制時(shí)只選取到可選取的內(nèi)容。
問(wèn)題解答
回答1:可以換種思路,比如把文本放到css中。css中的文本就完全無(wú)法選中和復(fù)制了。隨手寫(xiě)了個(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被禁止啦!'); }}
如果全選有問(wèn)題,也可以禁止ctrl+A
相關(guān)文章:
1. mysql - 如何減少使用或者不用LEFT JOIN查詢?2. mysql - jdbc的問(wèn)題3. Python爬蟲(chóng)如何爬取span和span中間的內(nèi)容并分別存入字典里?4. python - 我在使用pip install -r requirements.txt下載時(shí),為什么部分能下載,部分不能下載5. 視頻文件不能播放,怎么辦?6. python - Scrapy存在內(nèi)存泄漏的問(wèn)題。7. html5 - H5 audio 微信端 在IOS上不能播放音樂(lè)8. mysql - 分庫(kù)分表、分區(qū)、讀寫(xiě)分離 這些都是用在什么場(chǎng)景下 ,會(huì)帶來(lái)哪些效率或者其他方面的好處9. python - 編碼問(wèn)題求助10. mysql - 千萬(wàn)級(jí)數(shù)據(jù)的表,添加unique約束,insert會(huì)不會(huì)很慢?
