javascript - 有没有办法在 JavaScript/jQuery 中强制 DOM 焦点?

标签 javascript jquery ajax asynchronous race-condition

我有一些代码可以根据用户的选择动态加载选择框。

我在里面有代码指示要像这样选择一个特定的选项:

    //returns a string of <option>s by ID
    $('#subtopic_id').load('ajax.php?f=newSubtopic&topic_id=' + id);
    $('#subtopic_id').removeAttr('disabled');
    alert('hi');
    $('#subtopic_id').val(66); //forces SELECT box to show a specific option

但是,只有当我在上面的代码中有 alert('hi'); 时它才有效。当我删除 alert 行时,试图强制选择 66 的选择框似乎不起作用。

可能出了什么问题?我只能想象 alert 以某种方式捕获了焦点,或者可能引入了延迟,或者做了一些其他让下一行工作的魔法。

最佳答案

问题是因为 load() 是异步的,因此您需要提供一个回调函数,以便在 AJAX 请求完成并且内容已放入 DOM 时执行。只有这样你才能设置你需要的val()。试试这个:

$('#subtopic_id').load('ajax.php?f=newSubtopic&topic_id=' + id, function() {
  $(this).prop('disabled', false).val('66');
});

关于javascript - 有没有办法在 JavaScript/jQuery 中强制 DOM 焦点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42491213/

相关文章:

javascript - 如何在javascript中将嵌套对象转换为对象数组

javascript - SVG 中 Firefox 中的 onmouseover 事件

javascript - 使用数据属性将鼠标悬停在链接上时更改(和淡入/淡出)图像

python - Django:进行 ajax 调用时出现错误 500(内部服务器错误)

javascript - ajax 从远程服务器获取图像

php - Javascript 自动弹出(无需点击按钮)

javascript - Uncaught ReferenceError : $ is not defined error in jQuery. 表显示未定义

javascript - 如何在javascript中获取嵌套数组中值的indexOf位置?

javascript - 如何防止 Meteor.js 模板在没有数据的情况下呈现

javascript - 设置 colorbox lightbox ajax href 变量