<script language="Javascript">
window.setInterval("clipboardData.setData('text','')",100);
</script>
以上代碼是每100毫秒清空一次粘貼板操作。當頁面加載時腳本程序就開始自動執行。但這樣有個弊端,不管網頁被最小化還是怎么的只要這個窗口開著我們電腦所有的復制操作都無法進行(腳本一直在清空粘貼板),從某種意義上講是達到預期效果了,但有些欠佳:(。
我們知道所有的控件都有onfocus和onblur事件,window窗口也不例外。我們通過利用這兩個事件,只有在當前窗口處于活動狀態時才執行清空操作,否則停止執行。代碼如下:
<script language="Javascript">
var interval
window.onfocus=function(){interval=window.setInterval("clipboardData.setData('text','')",100);}
window.onblur=function(){window.clearInterval(interval);}
</script>
這樣就可以完美的解決這個問題。但對于不將截屏內容放入粘貼板的截屏程序來說此方法還是心有余而力不足的。
最新測試實踐發現使用onfocus和onblur事件的方法也不盡如人意,當焦點指向程序頁面內其他控件(即使Table)時,window將失去焦點從而觸發onblur事件停止執行清空粘貼板命令,難道需要遍歷所有控件為其onfocus和onblur綁定事件?有些迷茫與失望。
另window.onfocus只是document的onfocus,如果焦點在地址欄或菜單之類的地方onfocus也將失效。
僅以此文字記錄自己半天時間研究JS的心得。
禁止打印只需將如果下樣式代碼放入程序即可(打印出的頁面內容將為空白):
<style>@media print{body{display:none}}</style>
禁止復制、選擇、右鍵菜單:
<script language=Javascript>
function click() {
return false;}
function click1(){if (event.button==2) {return false; }}
function CtrlKeyDown(){
if (event.keyCode==67&&event.ctrlKey)
{
clipboardData.setData('text','');
return false;
}
}
document.onkeydown=CtrlKeyDown;
document.onselectstart=click;
document.onmousedown=click1;
</script>
<noscript><iframe src=*.html></iframe></noscript>
<script language=Javascript>
<!--
if (window.Event)
document.captureEvents(Event.MOUSEUP);
function nocontextmenu(){
event.cancelBubble = true
event.returnValue = false;
return false;
}
function norightclick(e){
if (window.Event){
if (e.which == 2 || e.which == 3)
return false;
}
else if (event.button == 2 || event.button == 3)
{
event.cancelBubble = true;
event.returnValue = false;return false;}
}
document.oncontextmenu = nocontextmenu; // for IE5+
document.onmousedown = norightclick; // for all others
//--></script>
以上代碼在IE6.0環境運行正常。
JavaScript技術:JS應用之禁止抓屏、復制、打印,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。