详解jQuery UI库中文本输入自动补全功能的用法_jquery

自动补全(autocomplete),是一个可以减少用户输入完整信息的UI 工具。一般在
输入邮箱、搜索关键字等,然后提取出相应完整字符串供用户选择。

一.调用autocomplete()方法

$('#email').autocomplete({ 

  source : ['aaa@163.com', 'bbb@163.com', 'ccc@163.com'], 

}); 

二.修改autocomplete()样式
   由于autocomplete()方法是弹窗,然后鼠标悬停的样式。通过Firebug 想获取到
悬停时背景的样式,可以直接通过jquery.ui.css 里面找相应的CSS。

//无须修改ui 里的CSS,直接用style.css 替代掉
.ui-menu-item a.ui-state-focus { 

  background:url(../img/xxx.png); 

} 

三.autocomplete()方法的属性
   自动补全方法有两种形式:1.autocomplete(options),options 是以对象键值对
的形式传参,每个键值对表示一个选项;2.autocomplete('action', param),action
是操作对话框方法的字符串,param 则是options 的某个选项。

属性 默认值/类型 说明
disabled  false/布尔值 设置为true,将禁止显示自动补全。
source  无/数组 指定数据源,可以是本地的,也可以是远程的。
minLength  1/数值 默认为1,触发补全列表最少输入字符数。
delay  300/数值 默认为300 毫秒,延迟显示设置。
autoFocus  false/布尔值 设置为true 时,第一个项目会自动被选定。
$('#email').autocomplete({ 

  source : ['aaa@163.com', 'bbb@163.com', 'ccc@163.com'], 

  disabled : false, 

  minLength : 2, 

  delay : 50, 

  autoFocus : true, 

});
属性 默认值/类型 说明
position 无/对象
使用对象的键值对赋值,有两个属性:my 和at

表示坐标。my 是以目标点左上角为基准,at 以

目标点右下角为基准。

$('#email').autocomplete({ 

  position : { 

   my : 'left center', 

   at : 'right center' 

  } 

});

四.autocomplete()方法的事件
   除了属性设置外,autocomplete()方法也提供了大量的事件。这些事件可以给各
种不同状态时提供回调函数。这些回调函数中的this 值等于对话框内容的div 对象,不
是整个对话框的div。
autocomplete 事件选项

事件名 说明
create
当自动补全被创建时会调用create 方法,该方法有两个

参数(event, ui)。此事件中的ui 参数为空。

open
当自动补全被显示时,会调用open 方法,该方法有两个

参数(event, ui)。此事件中的ui 参数为空。

close
当自动补全被关闭时,会调用close 方法,该方法有两个

参数(event, ui)。此事件中的ui 参数为空。

focus
当自动补全获取焦点时,会调用focus 方法,该方法有两

个参数(event, ui)。此事件中的ui 有一个子属性对象item,

分别有两个属性:label,补全列表显示的文本;value,

将要输入框的值。一般label 和value 值相同。

select
当自动补全获被选定时,会调用select 方法,该方法有两

个参数(event, ui)。此事件中的ui 有一个子属性对象item,

分别有两个属性:label,补全列表显示的文本;value,

将要输入框的值。一般label 和value 值相同。

change
当自动补全失去焦点且内容发生改变时,会调用change

方法,该方法有两个参数(event, ui)。此事件中的ui 参数

为空。

search
当自动补全搜索完成后,会调用search 方法,该方法有

两个参数(event, ui)。此事件中的ui 参数为空。

response
当自动补全搜索完成后,在菜单显示之前,会调用

response 方法,该方法有两个参数(event, ui)。此事件中

的ui 参数有一个子对象content,他会返回label 和value

值,可通过遍历了解。

$('#email').autocomplete({ 

  source : ['aaa@163.com', 'bbb@163.com', 'ccc@163.com'], 

  disabled : false, 

  minLength : 1, 

  delay : 0, 

  focus : function (e, ui) { 

   ui.item.value = '123'; 

  }, 

  select : function (e, ui) { 

    ui.item.value = '123'; 

  }, 

  change : function (e, ui) { 

   alert(''); 

  }, 

  search : function (e, ui) { 

   alert(''); 

  }, 

});
autocomplete('action', param)方法
方法 返回值 说明
autocomplete('close')  jQuery 对象 关闭自动补齐
autocomplete('disable')  jQuery 对象 禁用自动补齐
autocomplete('enable')  jQuery 对象 启用自动补齐
autocomplete('destroy')  jQuery 对象 删除自动补齐,直接阻断
autocomplete('widget')  jQuery 对象 获取工具提示的jQuery 对象
autocomplete('search',value)  jQuery 对象 在数据源获取匹配的字符串
autocomplete('option', param)  一般值 获取options 属性的值
autocomplete('option', param,value)  jQuery 对象 设置options 属性的值

$('#reg').on('autocompleteopen', function () {

alert('打开时触发!');

});

五、邮箱自动补全
  通过自动补全source 属性的function 回调函数,来动态的设置数据源,以达到可以
实现邮箱补全功能。

1.数据源function
   自动补全UI 的source 不但可以是数组,也可以是function 回调函数。提供了自带的
两个参数设置动态的数据源。

$('#email').autocomplete({ 

  source : function (request, response) { 

   alert(request.term);    //可以获取你输入的值 

   response(['aa', 'aaaa', 'aaaaaa', 'bb']);    //展示补全结果 

  }, 

});

注意:这里的response 不会根据你搜索关键字而过滤无关结果,而是把整个结果全部呈现出
来。因为source 数据源,本身就是动态改变的,就由自定义,从而放弃系统内置的搜索能力。

2.邮箱自动补全

$('#email').autocomplete({ 

  autoFocus : true, 

  delay : 0, 

  source : function (request, response) { 

   var hosts = ['qq.com','163.com', '263.com', 'gmail.com', 'hotmail.com'],    //起始 

     term = request.term,    //获取输入值 

     ix = term.indexOf('@'),    //@ 

     name = term,    //用户名 

     host = '',    //域名  

     result = [];    //结果 

   //结果第一条是自己输入
   result.push(term); 

   if (ix > -1) {    //如果有@的时候 

     name = term.slice(0, ix);    //得到用户名 

     host = term.slice(ix + 1);    //得到域名 

   } 

   if (name) { 

     //得到找到的域名
     var findedHosts = (host ? $.grep(hosts, function (value, index) { 

                 return value.indexOf(host) > -1; 

               }) : hosts), 

     //最终列表的邮箱
     findedResults = $.map(findedHosts, function (value, index) { 

              return name + '@' + value; 

             }); 

     //增加一个自我输入
     result = result.concat(findedResults); 

   } 

   response(result); 

  }, 

});

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索jquery
, jqueryui
自动补全
jquery ui自动补全、jquery的用法详解、h ui admin 搜索补全、jquery自动补全插件、jquery 自动补全,以便于您获取更多的相关知识。

时间: 2024-11-18 23:17:16

详解jQuery UI库中文本输入自动补全功能的用法_jquery的相关文章

jQuery实现文本框邮箱输入自动补全效果_jquery

  邮箱自动完成的效果在网站上大多都看过,但是质量参差不齐,今天突然在网上看到一篇博客,感觉这个插件很好,就想来写一下分享给大家!  效果图如下: 完整demo代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="

jQuery实现邮箱下拉列表自动补全功能_jquery

记得,在上个项目中,遇到这样一个需求,网站要求填写邮箱的时候,还没有填写完,就会出现一系列下拉列表,帮助自动补全邮箱的功能.今天小编给给大家分享下我基于jquery是怎么实现此功能的! 功能简述 •填写邮箱名字,出现下拉列表,自动补全邮箱 •点击上下按键,选取下拉列表邮箱 •按回车键,选中列表内容,隐藏下拉列表 •鼠标经过,下拉列表选项设置为高亮 •鼠标点击,选中下拉列表选项,隐藏下拉列表 HTML HTML代码很简单,我们就一个简单的输入框,然后一个ul标签,在内部可以放好多li标签. <ht

jQuery实现Email邮箱地址自动补全功能代码_jquery

本文实例讲述了jQuery实现Email邮箱地址自动补全功能代码.分享给大家供大家参考,具体如下: jQuery Email邮箱地址自动补全代码,输入Email时,会自动加入@符号,在输入框中输入"qq"."Sina"."163"等等可以看到效果:鼠标经过提示Email时,高亮该条Email,鼠标点击Email时,文本框内容替换成该条Email,并删除提示层. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js

jquery实现邮箱自动补全功能

 这篇文章主要介绍了jquery实现邮箱自动补全功能,大家参考使用吧  代码如下: (function($){     $.fn.autoMail = function(options){          var autoMail = $(this);          var _value   = '';          var _index   = -1;          var _width   = autoMail.outerWidth();          var _heigh

实例讲解Android中的AutoCompleteTextView自动补全组件_Android

AutoCompleteTextView是一个具有自动补全功能的EditView,当用户输入数据后,AutoCompleteTextView就会将用户输入的数据与他自己的adapter中的数据对比,如果用户数据与adapter中的某条数据的开始部分完全匹配,那么adapter中的这条数据就会出现在下拉提示框中. 其常用属性定义如下 <AutoCompleteTextView android:id="@+id/mp002_top_place_input" android:layou

如何在Oh-My-Zsh中启用Heroku命令补全功能

如何在Oh-My-Zsh中启用Heroku命令补全功能 Heroku客户端是创建和管理Heroku应用的命令行界面工具. 需求: Heroku toolbelt Oh-My-Zsh (如何安装) 本文不是讲关于heroku的知识,也不是讲关于heroku的使用细节,而是仅仅展示给用户他们怎样可以使用oh-my-zsh来方便地敲入heroku命令.此外你还应该安装heroku toolbelt来进行本文的相应的操作.对于Ubuntu和Debian发行版,你可以通过运行下面的命令来安装: wget

实例讲解Android中的AutoCompleteTextView自动补全组件

AutoCompleteTextView是一个具有自动补全功能的EditView,当用户输入数据后,AutoCompleteTextView就会将用户输入的数据与他自己的adapter中的数据对比,如果用户数据与adapter中的某条数据的开始部分完全匹配,那么adapter中的这条数据就会出现在下拉提示框中. 其常用属性定义如下 <AutoCompleteTextView android:id="@+id/mp002_top_place_input" android:layou

基于jquery实现的自动补全功能

 这篇文章主要介绍了基于jquery实现的自动补全功能的方法,涉及jQuery操作数据实现补全的技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了基于jquery实现的自动补全功能的方法.分享给大家供大家参考.具体实现方法如下:   代码如下: $(function() { // 自动补全 var maxcount = 0;// 表示他最大的值 var thisCount =0;// 初始化他框的位置 $("body").prepend("<div

jQuery UI库中dialog对话框功能使用全解析_jquery

   对话框(dialog),是jQuery UI 非常重要的一个功能.它彻底的代替了JavaScript 的alert().prompt()等方法,也避免了新窗口或页面的繁杂冗余. 一.开启多个dialog   只要设置不同的id 即可实现. $('#x').dialog(); $('#y').dialog(); 二.修改dialog 样式   在弹出的dialog 对话框中,在火狐浏览器中打开Firebug 或者右击->查看 元素.可以看看dialog 的样式,对dialog 的标题背景进行