在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