【问题标题】:Detecting jQuery UI autocomplete检测 jQuery UI 自动完成
【发布时间】:2010-09-20 06:21:49
【问题描述】:

如何检测输入框当前是否为 jQuery UI 自动完成?似乎没有本机方法,但我希望有这样简单的东西:

if ($("#q").autocomplete)
{
  //Do something
}

然而,这个条件似乎总是返回 true。

【问题讨论】:

    标签: jquery jquery-ui


    【解决方案1】:
    if ($("#q").hasClass("ac_input")) {
        // do something
    }
    

    更新

    JQuery UI 自动完成小部件中的类名现在是“ui-autocomplete-input”,因此代码将是:

    if ($("#q").hasClass("ui-autocomplete-input")) {
        // do something
    }
    

    【讨论】:

      【解决方案2】:

      您还可以通过以下代码行找到附加到输入元素的自动完成行为:

      if ($('Selector').data('autocomplete')) {
      }
      

      【讨论】:

        【解决方案3】:

        如果页面已经包含了自动完成 jquery UI 插件,并且您只是想查看是否已为特定(输入)元素设置了自动完成功能,您可以使用 官方 API 方法 如下图:

        if ($("#q").autocomplete("instance")) {
            console.log("autocomplete already setup for #q");
        } else {
            console.log("NO autocomplete for #q");
        }
        

        更多详情请关注http://api.jqueryui.com/autocomplete/#method-instance

        【讨论】:

          【解决方案4】:

          你可以使用

          if( $.isFunction( $.fn.autocomplete ) ){ }
          

          .isFunction 是 jQuery 库的一部分。 (引用:http://james.padolsey.com/jquery/....isFunction

          【讨论】:

          • 这只是检查autocomplete 是否作为函数存在,这意味着自动完成插件已加载到内存中。但这不是问题要问的。
          【解决方案5】:

          这是真的,因为一旦你包含了自动完成 js,每个 $() 对象现在都定义了一个 autocomplete() 方法(如果你想为这些元素激活自动完成)。您的 if() 只是说该函数不为空。

          不幸的是,我没有可以检查此内容的系统(今天将笔记本电脑留在家中),但我相信自动完成功能会为其使用的元素添加一个 css 类名称。你可以找那个。

          【讨论】:

            猜你喜欢
            • 2011-07-23
            • 1970-01-01
            • 1970-01-01
            • 2011-06-10
            • 2011-05-31
            • 1970-01-01
            相关资源
            最近更新 更多