【发布时间】:2010-10-25 20:59:03
【问题描述】:
附加的 javascript 在 safari 中不起作用。
此脚本在离开当前页面之前显示一条确认消息。
令人惊讶的是,这在 safari 中第一次起作用(但在随后的提交过程中却没有)。
场景:
- 用户进行了一些更改并按下提交按钮
- 向用户显示确认消息
- 用户决定按取消按钮以留在同一页面上
- 但后记用户无法再次调用提交。
- 提交按钮不起作用。
P.S:此代码与其他浏览器完美兼容,例如 IE7/8、FireFox。
function checksave() {
if (formIsDirty(myForm)) {
return "The form has been changed...";
}
}
function formIsDirty(form) {
for (var i = 0; i < form.elements.length; i++) {
var element = form.elements[i];
var type = element.type;
if (type == "checkbox" || type == "radio") {
if (element.checked != element.defaultChecked) {
return true;
}
}
else if (type == "hidden" || type == "password" || type == "text" ||
type == "textarea") {
if (element.value != element.defaultValue) {
return true;
}
}
else if (type == "select-one" || type == "select-multiple") {
for (var j = 0; j < element.options.length; j++) {
if (element.options[j].selected !=
element.options[j].defaultSelected) {
return true;
}
}
}
}
return false;
}
<body OnBeforeUnload ="return checksave();">
<form id="myForm" >
<table border="1">
<tr> <td>Enter Text:</td><td><input id="text1" type="text" value=""/> <br/> </td></tr>
<tr> <td><input id="button1" type="submit" value="Submit1"/> <br/> </td> <td><input id="button2" type="submit" value="Submit2"/> <br/> </td></tr>
</table>
</form>
</body>
【问题讨论】:
-
在这里回答了吗? stackoverflow.com/questions/803887/…
标签: javascript safari onbeforeunload