用javascript實現既能禁止頁面滑鼠右鍵查看 同時又能查看頁面文字框右鍵菜單

來源:互聯網
上載者:User
在CSDN上,看到有人問這個問題。就是若把頁面右鍵屏蔽的話,文字框上的右鍵菜單同樣也給屏蔽,問如何能夠將文字框的右鍵菜單顯示出來。
解決思路:首先,要在頁面初始化時將頁面右鍵菜單屏蔽

次,在欲解除右鍵限制的文字框獲得焦點時,啟用頁面document的右鍵菜單。可以用在文字框中的onmousedown事件中,但推薦用在
onfocus事件中,若使用的onmousedown的話,則按鍵盤上摸擬右鍵的按鍵(在右win鍵右邊)不響應;若用onfocus事件,則能順利響
應。
最後,當該文字框失去焦點時,需將頁面document的右鍵菜單屏蔽,用文字框的onblur事件即可。
要注意的是IE和Firefox的相容性問題:
頁面初始化時,若使用這樣的語句<body oncontextmenu="return false;">

則在IE中沒有影響,但Firefox中文字框右鍵菜單不能顯示。
使用下列語句:<body onload="hidemenu();">

將oncontext處理代碼寫在函數中,IE和Firefox中均能正常響應。
下面是測試頁面的原始碼:<html>
<head>
<title>屏蔽頁面右鍵,但不屏蔽某HTML元素的右鍵響應</title>
<script language="javascript">
    function hidemenu()
    {
        document.oncontextmenu = function(){return false;}
    }
    
    function showmenu()
    {
        document.oncontextmenu = function(){return true;}
    }
</script>
</head>
<body onload="hidemenu();">
響應右鍵:<input type="text" id="text1" onfocus="showmenu();" onblur="hidemenu();">
<br>
不響應右鍵:<input type="text" id="text2">
</body>
</html>

原始碼: http://files.cnblogs.com/redleaf1995/right.rar

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.