jQuery Click Event CheckBox 更改了 Ajax 调用
jQuery Click Event CheckBox Changed Ajax Call
我有三个复选框,它们从模型中填充了选中/未选中的值。我正在使用 Ajax 帖子按钮单击事件来调用每个复选框更改事件的控制器操作,以便更新数据库。
以下是其中一个复选框的代码(除了选择器 ID 之外,它们都是一样的):
$(document).ready(function () {
//document.getElementById('UpdateButton').onclick = function () {
$("UpdateButton").click = function () {
$('#NatAm').change(function () {
// if ($('#NatAm').is(':checked')) {
$.ajax({
//url: '@Url.Action("NativeUpdate", "Transactions")',
url: '/Transactions/NativeUpdate',
//data: { isNativeUp: true },
type: 'POST',
dataType: "json"
});
//}
});
编辑(HTML/视图代码):
@Html.CheckBox("NatAm", (bool)@ViewBag.NativeAm)
<input name="UpdateButton" id="UpdateButton" type="submit" value="Update" style="margin-left: 15px; margin-top: 3px;" class="btn btn-success" />
我无法让它工作。在添加按钮之前,ajax 帖子工作正常。感谢您的帮助!
您的点击处理程序不正确。您需要传入按钮的 id 并使用 jQuery 单击处理程序。您也不需要嵌套处理程序:
$(document).ready(function() {
$("#UpdateButton").click(update);
$('#NatAm').change(update);
});
function update() {
$.ajax({
url: '/Transactions/NativeUpdate',
type: 'POST',
dataType: 'json'
});
}
JSFiddle 演示:https://jsfiddle.net/vLzwuwdo/
你告诉JQuery寻找"UpdateButton"标签,而这些标签在你的例子中是不存在的。您缺少指示按钮中 ID 的 #。
试试这个
$(document).ready(function () {
//document.getElementById('UpdateButton').onclick = function () {
$("#UpdateButton").click(function () {
$('#NatAm').change(function () {
// if ($('#NatAm').is(':checked')) {
$.ajax({
//url: '@Url.Action("NativeUpdate", "Transactions")',
url: '/Transactions/NativeUpdate',
//data: { isNativeUp: true },
type: 'POST',
dataType: "json"
});
//}
}));
-
id
在同一文档中应该是唯一的(NatAm
和UpdateButton
),用全局类替换重复的将解决第一个问题。 -
您不应该在另一个元素中定义事件,因为每次触发第一个时,它都会为元素创建新事件,在您的情况下,每次单击新的更改事件时,都会创建并附加到带有
NatAm
的第一个元素。
希望这有帮助。
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作