gpt4 book ai didi

jquery - 通过 Ajax 提交的多个 Jquery 日期选择器和表单

转载 作者:行者123 更新时间:2023-12-01 04:20:21 27 4
gpt4 key购买 nike

有人可以帮助我为以下流程创建函数吗?我想在一个页面上有许多日期选择器,每个日期选择器都有不同的形式。然后onChange,提交正确的表单。我目前正在一遍又一遍地重复代码以使此行为发挥作用。这是该页面的所有代码。

<html>
<head>
<link rel='stylesheet' type='text/css' media='all' href='style.css' />
<link rel='stylesheet' type='text/css' media='all' href='jqueryui.css' />
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.18/jquery-ui.min.js"></script>

<script type="text/javascript">
$(document).ready(function () {
var $datepickers = $(".datepick");
var $setallow = $(".showdate");
var $removeallow = $(".hidedate");

$removeallow.click(function() {
var $remove = $(this).closest("form");
$remove.children(".datepick").hide("normal");
var formData = $remove.serialize();
submitForm(formData);
});
$setallow.click(function() {
var $allow = $(this).closest("form");
$allow.children(".datepick").show("normal");
var formData = $allow.serialize();
submitForm(formData);
});

$datepickers.datepicker({ dateFormat: 'yy-mm-dd' });
$datepickers.change(function() {
var $form = $(this).closest("form");
var formData = $form.serialize();
alert($form.serialize());
submitForm(formData);
});
});
</script>
</head>
<body>
<div>

<h1 align="center">Testing Datepicker</h1>
<div class="entry">
<table id="striping" cellspacing="0" cellpadding="2" width="100%"><tr class="textbold">
<td class="Label" nowrap="nowrap" width="500">
Title Name
</td>
<td class="Label" align="center" nowrap="nowrap" width="70">
Show</td>
<td class="Label" align="center" nowrap="nowrap" width="100">
Don't Show
</td>
<td class="Label" align="left" nowrap="nowrap" width="100">
Date (Year-Month-Day)
</td></tr>


<tr id="highlight">
<td nowrap="nowrap" height="33">Title 19</td>

<form id="form19">
<input name="id" type="hidden" value="19" />
<td align="center" nowrap="nowrap">
<input name="allow" class="showdate" type="radio" value="yes" id="show19" />
</td>
<td align="center" nowrap="nowrap">
<input name="allow" class="hidedate" type="radio" value="no" id="hide19" checked="checked" />
</td>
<td align="center" nowrap="nowrap">
<table width="100%">
<tr><td>
<input name="allowdate" class="datepick" id="datepicker19" type="text" size="12" maxlength="10" value="2012-06-25">
</td>
<td width="121"><div id="feedback"></div></td></tr>
</table>
</td>
<input type="hidden" name="token" value="69601e04ff3580695fa4aa1dc91d35b6" />
</form>

</tr>

<tr id="highlight">
<td nowrap="nowrap" height="33">Title 2</td>

<form id="form2">
<input name="id" type="hidden" value="2" />
<td align="center" nowrap="nowrap">
<input name="allow" class="showdate" type="radio" value="yes" id="show2" />
</td>
<td align="center" nowrap="nowrap">
<input name="allow" class="hidedate" type="radio" value="no" id="hide2" checked="checked" />
</td>
<td align="center" nowrap="nowrap">
<table width="100%">
<tr><td>
<input name="allowdate" class="datepick" id="datepicker2" type="text" size="12" maxlength="10" value="2012-06-25">
</td>
<td width="121"><div id="feedback"></div></td></tr>
</table>
</td>
<input type="hidden" name="token" value="69601e04ff3580695fa4aa1dc91d35b6" />
</form>

</tr>


</table>
</div>

<script>
function submitForm(formData) {
$.ajax({
type: "POST",
url: "update.php",
data: formData,
dataType: "json",
cache: false,
timeout: 8000,
success: function(data) {
$("#feedback").html('<img src="icon_updated.png" border="0" />').fadeIn("fast");
setTimeout("$('#feedback').fadeOut('slow')", 1000);
},
error: function(data) {
$("#feedback").html('<img src="icon_not_updated.png" border="0" />').fadeIn("fast");
setTimeout("$('#feedback').fadeOut('slow')", 1000);
}
});
};
</script>

</body>
</html>

我还尝试使用单选按钮来切换显示和不显示日期选择器元素,但没有成功。每页也有超过 2 个日期选择器。我想要一个datepicker和一个ajax function 。我已经尝试过上面的链接,但没有成功。感谢您的帮助。

最佳答案

以下内容应该适合您:

$(function() {
//var $datepickers = $("#datepicker1, #datepicker2, #datepicker3");
var $datepickers = $(".datepick");

$datepickers.datepicker({ dateFormat: 'yy-mm-dd' });
$datepickers.change(function() {
var $form = $(this).closest('form');
var formData = $form.serialize();

submitForm(formData);
});
});

Live DEMO

要简化设置为 $datepicker 的选择器,您可以将一类 datepicker 添加到文本框。

关于jquery - 通过 Ajax 提交的多个 Jquery 日期选择器和表单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11174617/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com