Ajax 将成功函数的调用加倍
Ajax doubles calls to success function
我有以下js代码:
$('#btn_goals').on('click', function () {
$.ajax({
url: '/Goals/Index',
success: function (data) {
$('#region_content').html(data);
console.log("goals fires");
}
});
});
它在某些按钮单击时触发并且工作完美,除了一件奇怪的事情:它在第一个按钮单击时触发一次,在第二个按钮单击时触发两次,在第三次按钮单击时触发四倍,依此类推。
这是谷歌控制台输出:
1st click:
Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help, check http://xhr.spec.whatwg.org/.
content loaded myscript-002.js:8
2nd click:
content loaded myscript-002.js:8
content loaded VM43:8
3rd click:
content loaded myscript-002.js:8
content loaded VM43:8
content loaded VM43:8
content loaded VM43:8
等等。
原因是什么?
根据您提供的代码和信息,唯一合理的解释是,无论您从 AJAX 请求中以 HTML 代码返回什么,都会在相同的元素#btn_goals
上创建一个 click 事件处理程序。最有可能的是,使用相同的代码。
因此,请检查请求的结果并在必要时修复它。
如果问题是多次注册同一事件,请使用这个..
$('#btn_goals').off('click');
$('#btn_goals').on('click', function () {
$.ajax({
url: '/Goals/Index',
success: function (data) {
$('#region_content').html(data);
console.log("goals fires");
}
});
});
off()
方法清除使用 on() 方法附加的上一个事件。
第二种方法 #updated
$(document).off("userDistinctData");
$(document).on("userDistinctData", function (e) {
performAjaxCall();
}
);
var performDataCall = function () {
$.ajax({
url: '/Goals/Index',
success: function (data) {
$('#region_content').html(data);
console.log("goals fires");
}
});
};
$('#btn_goals').off('click');
$('#btn_goals').on('click', function () {
$(document).trigger({
type: "userDistinctData",
cData: data,
});
});
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量