- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个表格,它实际上由两个表格组成。每个表格都是一个预订表格。两种形式都有两个下拉列表 - destination from
和 destination to
。有一个偶数处理程序,它调用 AJAX 以在选择/更改目的地时获取可能的目的地
。
另一个事件处理程序(往返复选框)通过从第一个表单切换目的地来填充第二个表单下拉列表。
所以如果第一个表单有:
destination one: France
destination two: Austria
然后,如果选中round trip
,则立即填写第二个表单:
destination one: Austria
destination two: France
问题是这两个事件不能正确配合。
当这段代码被执行时:
id_form_1_destination_from.val(destination_to_0.val());
id_form_1_destination_to.val(destination_from_0.val());
id_form_1_destination_from.change();
id_form_1_destination_to.change();
第一行调用另一个填充第二个表单的处理程序(这是唯一不需要的情况)。由于它是 AJAX
,第二行取代了此 AJAX
,所以现在,第二个表单已正确填写(从第一个表单切换目的地),但是当 AJAX 完成时,它会改变目的地二
字段的选择。
有没有办法避免这种情况?例如关闭事件处理程序或更好地让 JQuery
等待 AJAX
完成然后继续。我不能只在 destination to
字段上执行 .off()
,因为我使用 select2
插件。
这是我的JQuery
:
$(document).ready(function () {
var destination_from_0 = $("#id_form-0-destination_from");
var destination_to_0 = $('#id_form-0-destination_to');
var ride_two = $('#ride_two');
$('.class-destination-from').on('change', function () {
destination_from_changed.call(this);
});
$("#id_round_trip").on('change', function () {
if (($('#id_round_trip').is(':checked')) ) {
var id_form_1_destination_from =$('#id_form-1-destination_from');
var id_form_1_destination_to = $('#id_form-1-destination_to');
ride_two.show('fast');
//id_form_1_destination_from.off();
id_form_1_destination_from.val(destination_to_0.val()).change();
//id_form_1_destination_from.on();
//id_form_1_destination_from.change();
id_form_1_destination_to.val(destination_from_0.val()).change();
}else{
ride_two.hide('fast');
ride_two.find(':input').not(':button, :submit, :reset, :checkbox, :radio').val('').change();
ride_two.find(':checkbox, :radio').prop('checked', false).change();
}
});
$('.class-destination-to').on('change', destination_to_changed);
});
function destination_to_changed() {
var destination_id = $(this).val();
var arrival_container = $(this).siblings('.arrival-container');
var departure_container = $(this).siblings('.departure-container');
if (destination_id == '') {
return;
}
$.ajax({
url: '/ajax/is-airport/' + destination_id + '/',
success: function (data) {
if (data.status == true) {
arrival_container.hide("slow");
departure_container.show("slow");
}
if (data.status == false) {
departure_container.hide("slow");
arrival_container.show("slow");
}
arrival_container.change();
departure_container.change();
}
})
}
function destination_from_changed() {
var destination_id = $(this).val();
if (destination_id == '') {
return;
}
var ajax_loading_image = $('#ajax-loading-image');
var destination_to = $(this).siblings('.class-destination-to');
destination_to.empty();
ajax_loading_image.show();
$.ajax({
url: '/ajax/get-destination-to-options/' + destination_id + '/',
async:false, // ADDED NOW - THIS HELPED BUT IT'S NOT NECESSARY EVERYTIME
success: function (data) {
ajax_loading_image.hide();
destination_to.append('<option value="" selected="selected">' + "---------" + '</option>');
$.each(data, function (key, value) {
destination_to.append('<option value="' + key + '">' + value + '</option>');
});
destination_to.change();
}
})
}
最佳答案
如果我没理解错的话,你遇到了并发问题。您基本上希望在调用第二个 ajax 调用之前终止您的第一个 ajax 调用,对吗?
我在您的代码中没有看到任何 ajax 请求,但我认为参数 async: false, 可能是您所需要的。
查看文档:http://api.jquery.com/jquery.ajax/
希望对你有帮助
关于javascript - JQuery 事件正在被另一个事件取代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38752874/
我有一个包含几行的 HTML 表格。 我最初为其中一些表格行 (TR) 提供了一个 ID,然后我将使用 javascript 通过一些新的动态内容来设置其中一些表格行的 INNERHTML。 但是,I
在以下(Clojure)SO问题中:my own interpose function as an exercise 接受的答案是这样的: Replace your recursive call wi
我目前正在使用 Delphi7 和 ASTA 来处理客户端服务器与 Advantage DB 的通信。 我正在转向 Rad Studio XE Enterprise,并希望切换到不同但相似的解决方案,
当我尝试更新软件包时,我总是收到这条消息,我通常只是继续进行,一切都会正常进行。但我担心我不小心创建了一个比我想要的复杂得多的 Anaconda 环境。此线程 ( What does "the fol
这个问题在这里已经有了答案: 关闭 13 年前。 Possible Duplicate: Why not use tables for layout in HTML? 我知道现在每个人都在关注 DI
作为一名 Java 后端开发,日常工作中免不了要生成数据库表对应的持久化对象 PO,操作数据库的接口 DAO,以及 CRUD 的 XML,也就是 mapper。 Mybatis Generator 是
我需要用 bitshift 替换 Java 中的 Math.pow。 for (int i = n - 1; i >= 0; i--) Math.pow(16, n - i - 1) 其中 n
我对 Oracle 还很陌生。 可以肯定地说LTRIM(RTRIM())完全可以被 TRIM() 取代如果我想替换 Oracle 11g 中的前导和尾随空格? 此外,当我尝试在使用 JPA 的查询中使
此应用程序包含activity_main.xml、mainactivit.java 和一个Fragment 类。activity_main.xml 在RelativeLayout 中有一个Button
我正在研究将 Weblogic 10.x 替换为用于开发机器的 Apache Tomcat,我非常感谢任何人可能有的任何见解或建议。 任何试图在生产 webapp 服务器怪物上进行开发工作的人可能都知
我有以下 JS 代码,我想用 $ 符号替换所有 ₪ (₪)。 $(this).html($(this).html().replace(/₪/g,'$')); 但是它没有做任何事情。我还尝试
执行此操作的正确方法是什么?我有一个 标签,我想显示 那是内联的。 最佳答案 display: inline 应该可以解决问题。它将使 表现得像任何内联元素。 关于html - CSS:取代 h1 换
我有一个问题 - 当我改变方向时,我的第二个 fragment (此时处于 Activity 状态)被第一个 fragment 取代。我从来没有这样的行为,如果能解决它怎么办? 主要 Activity
我有多个结构,其格式与传递给 encodeParams 函数的 MapParameters 相同。不幸的是,对这些结构使用该函数会产生不需要的编码,包括嵌入的结构名称。无论如何,我可以使用 refle
前言 打开Android架构组件页面,我们可以发现一些最新发布的jetpack组件,如Room,DataStore, Paging3,DataBinding 等都支持了Flow。Google开
我正在尝试不区分大小写的模式匹配。为了学习,我尝试了以下方法,发现很难分析正在发生的事情。 String x = "Hello"; String pattern = "(?i)";
这个问题在这里已经有了答案: Why aren't my absolutely/fixed-positioned elements located where I expect? (3 个答案)
我有以下形式的 HTML 布局 .. .. // content .. 两个 header 都是 position: fixed 并设置为 header 1 刚好在 header 2 上方。这两个 h
阅读中this c++17 最终特性的总结我对结构化绑定(bind)的部分感到有点惊讶(强调我的): structured bindings Until now, there was a known
我正在集成一个用早期 Swift 编写的库。由于该库与 Swift 4 的兼容版本不可用,我正在自己删除错误。 有这一行: let pathBounds = CGPathGetBoundingBox(
我是一名优秀的程序员,十分优秀!