菜鸟教程小白 发表于 2022-12-12 17:10:53

跳转到下一个下拉菜单时,jQuery 级联下拉菜单在 iPhone 上不起作用


                                            <p><p>我的级联下拉菜单在桌面浏览器和 iPad 上运行良好,但我真的只需要它在 iOS 7 和 Android 上的 iPhone 上运行。问题出在 iPhone 上。如果我使用 > 按钮导航到下一个下拉列表,则在第一个下拉列表中选择一个选项后,它会在 ajax 调用完成之前切换,因此我的下拉列表要么为空,要么仍保留先前的选择。如果我点击完成,模糊事件就足以让它工作。</p>

<p>这是最简单的全功能示例:</p>

<pre><code>&lt;!DOCTYPE html&gt;
&lt;html&gt;
&lt;head&gt;
&lt;meta name=&#34;description&#34; content=&#34;Cascading dropdowns&#34; /&gt;
    &lt;meta http-equiv=&#34;Content-Type&#34; content=&#34;text/html; charset=UTF-8&#34; /&gt;
    &lt;meta name=&#34;viewport&#34; content=&#34;width=device-width, initial-scale=1&#34;&gt;
    &lt;link rel=&#34;stylesheet&#34; href=&#34;http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.css&#34; /&gt;
    &lt;script src=&#34;http://code.jquery.com/jquery-1.9.1.min.js&#34;&gt;&lt;/script&gt;
    &lt;script src=&#34;http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.js&#34;&gt;&lt;/script&gt;
    &lt;title&gt;Cascade&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;div data-role=&#34;page&#34; id=&#34;main&#34;&gt;
      &lt;div data-role=&#34;header&#34; class=&#34;jqm-header&#34;&gt;
      &lt;h1&gt;Cascade&lt;/h1&gt;
   &lt;/div&gt;
   &lt;div data-role=&#34;content&#34; &gt;
      &lt;div data-role=&#34;fieldcontain&#34;&gt;
          &lt;select name=&#34;agency&#34; id=&#34;agency&#34; &gt;
            &lt;option value=&#34;actransit&#34;&gt;AC Transit&lt;/option&gt;
            &lt;option value=&#34;emery&#34;&gt;Emeryville&lt;/option&gt;
            &lt;option value=&#34;sf-muni&#34;&gt;MUNI&lt;/option&gt;
          &lt;/select&gt;
          &lt;select name=&#34;selectRoute&#34; id=&#34;selectRoute&#34;&gt;&lt;/select&gt;
      &lt;/div&gt;
      &lt;/div&gt;
   &lt;/div&gt;
   &lt;script&gt;
    var nextBus = &#34;http://webservices.nextbus.com/service/publicXMLFeed?&#34;;

    function updateRoutes(agency) {
            $.ajax({
                type: &#34;GET&#34;,
                url: nextBus + &#34;command=routeList&amp;a=&#34; + agency,
                dataType: &#34;xml&#34;,
                success: function(xml) {
                  $(&#34;#selectRoute&#34;).children().remove();
                  $(xml).find(&#39;route&#39;).each(function(){
                        var tag = $(this).attr(&#39;tag&#39;);
                        var title = $(this).attr(&#39;title&#39;);
                        $(&#39;&lt;option value=&#34;&#39; + tag + &#39;&#34;&gt;&#39; + title+ &#39;&lt;/option&gt;&#39;).appendTo(&#34;#selectRoute&#34;);
                  });
                  $(&#34;#selectRoute&#34;).selectmenu(&#39;refresh&#39;);
                }
            });
    }

    $().ready(function(){

      $(&#34;#agency&#34;).blur (function (event)
      {
            var agency = $(&#34;#agency&#34;).val();
            updateRoutes(agency);
       });

    });
   &lt;/script&gt;
&lt;/body&gt;
&lt;/html&gt;
</code></pre>

<p>在某些浏览器上,可以通过按 Tab 键来模拟 > 按钮。我尝试添加它以延迟焦点更改,直到 ajax 完成:</p>

<pre><code>    $(&#34;#selectAgency&#34;).keypress (function(e) {
      if (e.keyCode == 9) {
            tabHappened = true;
            updateRoutes($(&#34;#selectAgency&#34;).val());
            e.preventDefault();
      }
      }
    });
</code></pre>

<p>然后在填充下一个下拉列表后,调用:</p>

<pre><code>                if (tabHappened) {
                  tabHappened = false;
                  $(&#34;#selectRoute&#34;).focus();
                }
</code></pre>

<p>但是我尝试过的 keypress、keydown 和其他几个似乎都没有触发,或者还有其他事情发生。我没有办法监控 iPhone 的 safari 浏览器上发生了哪些事件。我很欣赏任何让 iPhone 上的快速导航按钮与此配合使用的见解。提前感谢您抽出宝贵时间查看此内容。</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>对您的 ajax 使用 async=false 将阻止所有后续事件触发,直到它完成。见 <a href="https://stackoverflow.com/questions/1478295/what-does-async-false-do-in-jquery-ajax" rel="noreferrer noopener nofollow">What does &#34;async: false&#34; do in jQuery.ajax()?</a> </p></p>
                                   
                                                <p style="font-size: 20px;">关于跳转到下一个下拉菜单时,jQuery 级联下拉菜单在 iPhone 上不起作用,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/20626539/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/20626539/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: 跳转到下一个下拉菜单时,jQuery 级联下拉菜单在 iPhone 上不起作用