有的時候我們小伙伴想要用js實現頁面禁止🚫刷新的需求,讓我們上代碼:
document.onkeydown = function(e) {
e = window.event || e;
var k = e.keyCode;
//屏蔽ctrl+R,F5鍵,ctrl+F5鍵 F3鍵!驗證
if ((e.ctrlKey == true && k == 82) || (k == 116)
|| (e.ctrlKey == true && k == 116)||k==114) {
e.keyCode = 0;
alert("當前頁面不能刷新!");
e.returnValue = false;
e.cancelBubble = true;
return false;
}
if (k == 8) {
alert("不能返回或后退!");
e.keyCode = 0;
e.returnValue = false;
return false;
}
//屏蔽 Ctrl+n 驗證可以實現效果
if (e.ctrlKey && k == 78){
e.keyCode = 0;
e.returnValue = false;
e.cancelBubble = true;
return false;
}
//屏蔽F11 驗證可以實現效果
if (k == 122) {
e.keyCode = 0;
e.returnValue = false;
e.cancelBubble = true;
return false;
}
//屏蔽 shift+F10 驗證可以實現效果
if ((e.shiftKey && k == 121)||(e.ctrlKey && k == 121)){
e.keyCode = 0;
e.returnValue = false;
e.cancelBubble = true;
return false;
}
//屏蔽Alt+F4
if ((e.altKey) && (k== 115)) {
window.showModelessDialog("about:blank", "",
"dialogWidth:1px;dialogheight:1px");
e.keyCode = 0;
e.returnValue = false;
e.cancelBubble = true;
return false;
}
//屏蔽 Alt+ 方向鍵 ← ;屏蔽 Alt+ 方向鍵 → !驗證
if ((e.altKey)
&& ((k == 37) || (k == 39))) {
alert("不准你使用ALT+方向鍵前進或后退網頁!");
e.keyCode = 0;
e.returnValue = false;
e.cancelBubble = true;
return false;
}
};
//屏蔽右鍵菜單,!驗證
document.oncontextmenu = function(event) {
if (window.event) {
event = window.event;
}
try {
var the = event.srcElement;
if (!((the.tagName == "INPUT" && the.type.toLowerCase() == "text") || the.tagName == "TEXTAREA")) {
return false;
}
return true;
} catch (e) {
return false;
}
};
好了,以上就是我們用Js禁止頁面刷新的功能,如果還有什么Js功能的需求需要小曹幫助,歡迎給我留言吧。
