【发布时间】:2009-11-18 17:32:17
【问题描述】:
希望能得到大家的帮助。
我在检测表单是否已更改时使用此脚本。如果是这样,当我单击某个类的 href 链接时,会弹出一个确认窗口。
var formChanged = false;
$(document).ready(function() {
$('#my_form input[type=text].editable, #my_form textarea.editable').each(function (i) {
$(this).data('initial_value', $(this).val());
});
$('#my_form input[type=text].editable, #my_form textarea.editable').keyup(function() {
if ($(this).val() != $(this).data('initial_value')) {
handleFormChanged();
}
});
$('#my_form .editable').bind('change paste', function() {
handleFormChanged();
});
$('.navigation_link').bind("click", function () {
return confirmNavigation();
});
});
function handleFormChanged() {
$('#save_or_update').removeAttr('disabled');
formChanged = true;
}
function confirmNavigation() {
if (formChanged) {
return confirm('Are you sure? Your changes will be lost!');
} else {
return true;
}
}
一切正常,除了当我使用 jQuery 将一个链接插入到一个 div 上时(使链接“可见”):
$("button").click(function () {
var dylink = "<a href='#' class='navigation_link'>dynammic link</a>";
$("#tester").html(dylink);
});
如果我编辑表单然后单击“动态链接”,则不会弹出确认窗口。 另一个链接完美。知道它可能是什么吗?
这是html代码
<div><button>Show link</button></div>
<div id="tester"></div>
<div><a href="#" class="navigation_link">permanent link</a></div>
<form action="" method="get" id="my_form">
<input type="text" class="editable">
<input type="button" name="button" id="save_or_update" value="Submit" disabled="disabled" />
</form>
谢谢 /A
【问题讨论】: