Select2 "change" 事件不触发 htmx

Select2 "change" event does not trigger htmx

这是有效的,我想要它的方式:如果 <select> 被改变,那么 htmx 被触发。

<script src="https://unpkg.com/htmx.org@1.1.0"></script>

<table>
 <tr hx-post="//example.com" hx-trigger="change">
  <td>
    <select name="runner">
     <option value="a">a</option>
     <option value="b">b</option>
    </select>
  </td>
 </tr>
</table>

如果我使用 django-autocomplete-light 小部件,则它不起作用。

我用的是这个版本:django-autocomplete-light==3.8.1

如果我添加这个 JS,它就可以工作。欢迎更好的解决方案。

<script>
 window.addEventListener("DOMContentLoaded", (e) => {
  $('select').on('select2:select', function (e) {
   $(this).closest('tr').get(0).dispatchEvent(new Event('change'));
});
 })
</script>

刚遇到同样的问题,并使用以下修改版的 guettli 答案修复了它。

window.addEventListener("DOMContentLoaded", (e) => {
    $('select').on('select2:select', function (e) {
        $(this).closest('select').get(0).dispatchEvent(new Event('change'));
    });
});