`
waiting
  • 浏览: 235068 次
  • 性别: Icon_minigender_1
  • 来自: cq
社区版块
存档分类
最新评论

jQuery Combobox 扩展 (select+autocomplete)20110730更新

阅读更多

jQuery UI虽然比不上extJS的UI,但也在慢慢发展完善。

http://jqueryui.com/demos/autocomplete/#combobox  这个combobox扩展挺不错的,可以让下拉菜单具有字符自动完成过滤功能。

 

不过因为并非官方扩展所以存在一些问题,比如不支持参数设置;IE不支持combox的change事件 并且change会有滞后性,用于表单当通过按钮选择项目后直接提交会导致select选项未更新;双击输入框自动选中内容(方便快速删除)。

 

试着更新了代码,支持标准格式,

比如初始化时设定input框(虚拟的select框)宽度 : .combobox({size: 30})

或者对键盘输入延迟速度 .combobox({size: 30, delay: 50})  // 50ms

或者动态更改设置:

$(selector).combobox();

........

$(selector).combobox("option", "size",  50)

 

存在的问题:

 Firefox中当通过输入法输入中文第一次上屏时不会触发事件,需要继续输入中文或者输入一个空格再backspace删除掉这个空格才能触发自动完成事件。不过这是jQuery.UI键盘事件和中文输入法之间的兼容问题(西方人几乎不可能发现这种bug),和本插件无关。 (patch fixed)

 

效果可以到上面那个url查看。

 

html文件需要相应文件

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link type="text/css" rel="stylesheet" href="css/smoothness/jquery-ui-1.8.custom.css" />

<style>
button.comboboxButton {width:2em;  margin-left: -1px;}
button.comboboxButton .ui-button-text {display:block; line-height:1;}
.ui-autocomplete-input {margin:0; padding:0.3em 0 0.31em 0.3em; *padding:0.38em 0 0.46em 0.3em;}
</style>

</head>
<body>

<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="js/jquery-ui.min.js" ></script>
</body>
</html>

 

update:

  2010.07.23 修正输入+或者c++时抛出 'invalid quantifier +' 错误.  改善IE显示效果。 增加demo.

  2010.08.04    FF下给input添加input事件,补丁解决中文输入时触发匹配问题;
                       解决通过下拉菜单选择项目之后继续输入字符到不匹配状态后失焦时无法清空

  2010.08.12      jQuery.UI升级到1.84,在此基础上修改。

     add:    直接输入匹配字符失焦后保留
     add:    添加title参数,可自定义下拉按钮问题说明,默认是‘展开’

     20100804版本适用于jQuery.UI v1.82版本,不适用1.84版本

 

  2010.08.23  修正样式,输入框及按钮缩小

 

  2010.11.10 大图标样式有个更好的CSS,看18楼回复

 

  2011.07.30 更新<input>元素生成方式,增加destroy()方法。提供兼容jQuery1.6版本。

 

 

9
1
分享到:
评论
8 楼 waiting 2010-08-12  
yiqingxiao 写道
不错,之前试过,存在几个问题,fx 下不支持中文,下拉列表超长时,不自动滚动条的问题,都解决了,谢谢了


jQueryUI 1.84发布了。貌似autocomplete升级过,其中combobox示范代码也改进了,有空再研究下。
7 楼 yiqingxiao 2010-08-12  
不错,之前试过,存在几个问题,fx 下不支持中文,下拉列表超长时,不自动滚动条的问题,都解决了,谢谢了
6 楼 waiting 2010-08-12  
更正:‘如果要求完美及通用性,那么就得启用及QueryUI’ 是 ‘如果要求完美及通用性,那么就得弃用jQuery.autocomplete及jQueryUI (ui.button)’
5 楼 waiting 2010-08-11  
jollyja 写道
对jqueryui网站的代码进行了一定的改造,不过还有许多细节可以再优化:
1.下拉超长则纵向滚动条
2.默认回车事件(当输入出现下拉选框后,按回车,默认选中第一个)
3.输入值与列表值匹配时,不选择直接离开焦点,没有选择对应的值
4.下拉按钮最好统一命名,以便做disable操作
5.下来按钮如果能不用jqueryui的button做更好

1、源代码注释里面我添加这个功能的
/* FIX 下拉超长则纵向滚动条
<style>
.ui-button { margin-left: -1px; }
.ui-button-icon-only .ui-button-text { padding: 0.35em; }
.ui-autocomplete-input {margin: 0; padding: 0.48em 0em 0.47em 0.4em; *padding:0.72em 0 0.46em 0.4em;}
ul.ui-autocomplete {max-height: 280px; overflow-x: hidden; overflow-y: auto; padding:2px;}
</style>
*/


3、必须选择项目(鼠标点击或回车)才能触发相关事件,否则会有兼容问题。比如当输入有匹配时你不选择而是直接点击表单“提交”按钮,那么提交的(下拉菜单)结果将不会是预期值。jQueryUI官方代码原来就有这样的问题,所以我才去打补丁的。

4、jQuery.autocomplete 插件本身有disable的方法,改动下程序应该可以实现。

5 、我是方便直接在现有程序打补丁。如果要求完美及通用性,那么就得启用及QueryUI,而使用单行版autocomplete配合CSS来实现。这个工程不小,我对CSS不熟悉并且也没这个精力。 这个补丁版是为了应用在手头上一个项目才弄的。
4 楼 jollyja 2010-08-10  
对jqueryui网站的代码进行了一定的改造,不过还有许多细节可以再优化:
1.下拉超长则纵向滚动条
2.默认回车事件(当输入出现下拉选框后,按回车,默认选中第一个)
3.输入值与列表值匹配时,不选择直接离开焦点,没有选择对应的值
4.下拉按钮最好统一命名,以便做disable操作
5.下来按钮如果能不用jqueryui的button做更好
3 楼 waiting 2010-08-04  
hanz188 写道
试用了一下,代码写得挺好,可是它只支持英文,不支持中文,能否修改下。

IE、google浏览器下无此兼容问题。
针对FF打了个补丁,貌似解决中文输入问题。
兄弟试试看。
2 楼 waiting 2010-08-03  
我是在 jqueryui 网站Demo的基础上做的一点小小修改。源程序是老外写的,他们不会遇到需要打开输入法输入的情况,所以对中文的兼容性要差些。其实不是不支持中文,而是你最后输入上屏的中文无法触发事件,除非继续输入(在输入法中或者关闭输入法)。另外IE下好像中文是没问题的。
这个程序是基于jqueryUI.autocomplete的,要修改得动autocomplete的源代码,比较麻烦。哪位朋友给jquery提交个bug说说这个问题吧。 不过这个问题覆盖面太大,基本上所有input的change事件都会遇到。
1 楼 hanz188 2010-08-02  
试用了一下,代码写得挺好,可是它只支持英文,不支持中文,能否修改下。

相关推荐

    jQuery ui Combobox 扩展

    **jQuery UI Combobox扩展**是基于流行的JavaScript库jQuery和其UI框架jQuery UI的一个自定义组件。这个扩展将传统的HTML `&lt;select&gt;` 元素转化为一个功能更丰富、交互性更强的下拉框,提供了更好的用户体验。它结合...

    jquery实现autocomplete插件(文本框下拉选项).zip

    总结,jQuery实现的Autocomplete插件大大简化了文本框下拉选项的开发过程,通过合理的配置和扩展,可以适应各种复杂的业务场景。通过学习并实践这个插件,开发者能够提升Web应用的用户体验,实现更加智能化、人性化...

    使用JQuery UI完成可输入内容且自动匹配的的下拉列表

    `autocomplete`方法设置了数据源和`select`事件处理函数,当用户从建议列表中选择一个项时,它会更新输入框的值。`combobox`方法将普通的`autocomplete`转换为具有下拉列表外观的组合框。 通过这种方式,我们创建了...

    jquery complete

    Autocomplete还可以与其他jQuery UI组件结合使用,比如Combobox。此外,还可以通过自定义事件和方法扩展其功能,例如添加异步加载数据的能力,或实现分页、过滤等高级特性。 **总结** jQuery Autocomplete是提升...

    240多个jQuery UI插件

    - **jQuery ComboBox**: 创建可搜索的下拉列表。 - **jQuery controlled dependent (or Cascading) Select List**: 支持多级联动选择。 - **Multiple Selects**: 支持多选下拉列表。 - **Select box ...

    240多个jQuery插件

    1. jQuery Combobox:组合框插件,提供下拉列表和文本输入功能。 2. jQuery controlled dependent (or Cascading) Select List:联动下拉列表。 3. Multiple Selects:多选下拉框。 4. Select box manipulation:...

    240多个jQuery插件.doc

    jQuery不仅本身提供了丰富的API和强大的功能,还拥有大量的第三方插件,这些插件极大地扩展了jQuery的功能范围,使得开发者可以轻松地添加复杂的功能到自己的项目中,如动画、表单验证、文件上传等。下面将详细介绍...

    jquery插件表

    - **jQuery Combobox**:将下拉列表转换为组合框,提高用户选择效率。 - **jQuery controlled dependent (or Cascading) Select List**:创建级联选择框,实现数据联动。 - **Multiple Selects**:支持多选功能的...

    JQuery应用实例学习(强烈推荐)转载.doc

    对于表单的下拉框,jQuery Combobox 和 jQuery controlled dependent (or Cascading) Select List 等插件可以实现更高级的功能,如联动选择和多选。 此外,jQuery 还提供了许多其他工具,如时间、日期和颜色选取...

    jQuery常用操作

    为了方便开发者,jQuery社区开发了许多插件,例如`jQuery UI Autocomplete`或`Chosen.js`,它们可以快速实现Combobox功能,且具有丰富的自定义选项和良好的用户体验。 7. **Ajax交互(Ajax Interactions)**: 当...

    JQuerry 插件介绍

    jQuery 插件是一种扩展jQuery库功能的工具,它们通常是开发者为了解决特定问题或增加特定功能而创建的。这些插件极大地丰富了jQuery的功能,使得前端开发变得更加高效和便捷。以下是一些常见的jQuery插件及其用途: ...

    海量经典的jQuery插件集合

    jQuery ComboBox** - **功能概述**:增强下拉列表功能。 - **应用场景**:提供更好的用户交互体验。 **2. jQuery controlled dependent (or Cascading) Select List** - **功能概述**:实现级联选择功能。 - **...

    可填写js combox

    在实际项目中,JavaScript ComboBox还可以与其他技术结合,比如使用Ajax异步加载选项,或者配合Autocomplete功能提高输入效率。总之,理解并掌握JavaScript ComboBox的实现原理和最佳实践,能够帮助开发者创建更友好...

    强烈推荐240多个jQuery插件提供下载

    在本文中,我们将探讨一些强烈推荐的jQuery插件,这些插件可以极大地扩展jQuery的功能,帮助开发者提高工作效率并创建功能丰富的网页应用。 **文件上传**: - **Ajax File Upload** 提供了无刷新的文件上传功能,...

    c#可输入的下拉列表框

    在Web应用中,类似的功能可能通过HTML5的`&lt;select&gt;`元素配合`&lt;option&gt;`标签和JavaScript实现,或者使用第三方库如jQuery UI的`Autocomplete`插件,提供类似的功能。 总之,"C#可输入的下拉列表框"是一种强大且灵活...

Global site tag (gtag.js) - Google Analytics