select3是一款基于jQuery或Zepto.js的轻量级模块化select下拉列表框插件。select3下拉列表框可以进行单选、以tag的形式进行多选、可以指定输入类型格式、可以进行分组选择、还可以ajax进行远程调用。select3的特点有:
可以通过Bower来安装select3:
$ bower install select3
手动安装:在HTML的头部引入select3-full.js
和select3-full.css
文件。
<head> ... <link href="font-awesome.css" rel="stylesheet"> <link href="select3-full.css" rel="stylesheet"> ... <script src="jquery.js"></script> <script src="select3-full.js"></script> ... </head>
注意:默认的模板需要引入FontAwesome才能使用图标。
select3是内置模块化,使用Gulp来作为构建系统来构建文件。要安装必要的依赖,请运行:
$ npm install -g gulp $ npm install
然后你可以生成新的发行版文件:
$ npm run build
如果你想创建只包含你需要的模块的Select3库,你可以使用下面的命令:
$ gulp --modules=<comma-separated-module-list>
下面是可用的模块:
模块名称 | 描述 |
ajax | 用于创建ajax请求的模块。所有传递给ajax 对象的参数都由该模块提供。 |
async | Blocks the query function from calling its callback functions if another query has been issued since. This prevents out-of-order replies from remote sources to display incorrect results. This module is only needed if you use the query function and call its callbacks asynchronously. |
backdrop | 该模块为下拉列表框提供背景。backdrop用于确保下拉列表框打开时,用户点击下拉列表框的外面时下拉列表框被关闭。如果忽略该模块,插件会使用一个简单的替代方案来执行列表框的关闭动作,但是如果用户点击在一个带点击事件的元素上时,该元素的点击事件将被阻止。 |
base | Select3的基本模块。 |
diacritics | Diacritics support. This will make sure that "?ód?" will match when the user searches for "Lodz", for example. However, if you always query a server when searching for results, you may want to solve matching of diacritics server-side, in which case this module can be ommitted. |
dropdown | 实现dropdown功能的模块。 |
实现输入类型为"Email"的模块。这是一个特殊的列表框,可以多重选择、没有下拉列表。它使用专业的标记来识别电子邮件格式是否正确。 | |
keyboard | 提供下拉列表框的键盘支持。如果你不使用下拉框或只在手机上使用,可以不需要该模块。 |
locale | 默认模板的内容本地化模块。你可以自行决定是否在你的自定义模块中使用该模块。它也可以本地化ajax模块的信息。 |
multiple | 实现多选下拉列表框的模块。 |
single | 实现单选下拉列表框的模块。 |
submenu | 继承默认的dropdown,实现多级下拉列表功能。 |
templates | Select3默认的模板。 |
tokenizer | 默认的tokenizer实现。该模块用于支持tokenSeparators 选项。Support for tokenizers themselves is already included in the "multiple" module, so you can omit this module if you don't want to use any tokenizers or want to specify your own tokenizer. |
traditional | 该模块允许你将一个HTML5 <select> 表单元素转换为一个Select3实例。items将使用<option> 和<optgroup> 来初始化。 |
注意:构建系统会自动解决各个模块之间的依赖问题,所以你不用特别指定base模块,例如:
$ gulp --modules=multiple,dropdown
上面的代码会创建多重选择和下拉列表的select3文件。文件会存储在dist/select3-custom.js
中。dropdown没有backdrop特性,没有diacritics的支持,你还要提供自定义的带本地化内容的模板,并且你不能使用该文件来创建单选下拉列表框。
跟多详细信息请参考:https://github.com/arendjr/select3
select3的参数、事件及使用方法请查看DEMO。