jsfiddle 位于http://jsfiddle.net/whDm6/18/
如果我取消注释以下代码中的警报,更改表单值并刷新页面,它会显示警报。所以我知道代码正在执行到那时。但是,如果我将警报注释掉,它不会像我期望的那样显示 beforeunload 框。
我尝试使用 bind 并使用基本的 window.onbeforeunload = function() {} 而不将其与 Jquery 绑定,但这些都不起作用。
使用 Jquery 1.8.2
var currentUlValues = {};
currentUlValues['input1'] = "red";
currentUlValues['input2'] = "blue";
needToConfirm = true;
$(window).on('beforeunload', function(){
if (needToConfirm) {
$.each(currentUlValues, function(key, value) {
var elem = $("#"+key).val();
if (typeof elem !== 'undefined') {
if (elem != currentUlValues[key]) {
//alert(elem + " - " + currentUlValues[key]);
return 'Are you sure you want to leave?';
}
}
});
}
});
HTML 表单
<form>
<input id="input1" name="input1" type="text" value="red" />
<input id="input2" name="input2" type="text" value="blue" />
</form>