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

自动补全(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 的某个选项。

autocomplete 外观选项
属性 默认值/类型 说明
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, 

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

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

目标点右下角为基准。

$('#email').autocomplete({ 

  position : { 

   my : 'left center', 

   at : 'right center' 

  } 

});

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

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('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); 

  }, 

});
(0)

相关推荐

  • 基于jquery实现的类似百度搜索的输入框自动完成功能

    废话不多说,直观的看一下: 实现这个功能需要服务端配合.客户端通过脚本来展示从服务端取得的数据. 先看客户端的HTML: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  <html xmlns="http://www.w3.org/1999/x

  • jQuery实现自动输入email、时间和域名的方法

    本文实例讲述了jQuery实现自动输入email.时间和域名的方法.分享给大家供大家参考,具体如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"&

  • PHP结合jQuery.autocomplete插件实现输入自动完成提示的功能

    我们在很多项目中使用了搜索功能来帮助用户更快更准确的找到想要的信息.本文将介绍如何实现用户输入自动提示的功能,就像谷歌百度搜索引擎一样,当用户输入关键字时,输入框下方会有提示,将与关键字相关的信息展现出来供用户选择,提升了用户体验. 本文将使用jquery ui的autocomplete插件,结合后端PHP,数据源通过PHP读取mysql数据表的数据. XHTML 首先将jquery库和相关ui插件,以及css导入. 复制代码 代码如下: <link rel="stylesheet&quo

  • jQuery 自动增长的文本输入框实现代码

    为了提高用户体验,我在午休时候想起了是不是可以用jQuery写个插件.想到不如做到,果然,我实现了这个功能.在写这个插件时我潜意识里想到这样的插件网上应该有人写过,不过我并没有去搜索,你有兴趣可以找一找.下面是插件的源代码. 源代码 复制代码 代码如下: ;(function($) { $.fn.autoSizeText = function(settings) { var _defaultSettings = {min:20,max:40}; var _settings = $.extend(

  • jQuery实现感应鼠标动画效果自动伸长的输入框实例

    本文实例讲述了jQuery实现感应鼠标动画效果自动伸长的输入框.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999

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

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

  • jquery.fastLiveFilter.js实现输入自动过滤的方法

    本文实例讲述了jquery.fastLiveFilter.js实现输入自动过滤的方法.分享给大家供大家参考.具体如下: 本效果是使用jquery.fastLiveFilter.js插件来实现的,类似于搜索框的输入提示功能,实现对匹配项目的自动过滤功能,当你输入的时候,会根据输入的字符智能匹配符合的内容,自动列出来,提高人性化操作体验,如果您对jquery.fastLiveFilter.js插件的用法感兴趣,这是个很不错的例子. 运行效果截图如下: 具体代码如下: <!doctype html>

  • jquery判断字符输入个数(数字英文长度记为1,中文记为2,超过长度自动截取)

    1. $('textarea#txtPrizeNote'); //表示textarea控件名称 2. 'span' 显示剩余字数的标签 HTML: 复制代码 代码如下: <div> <textarea id="txtPrizeNote" runat="server" height="74px" width="480px" maxlength="10" style="width:

  • jquery 实现输入邮箱时自动补全下拉提示功能

    记得去年做某个项目的时候,用到了邮箱输入自动提示功能,于是网上搜了一下,发现了这个写得不错,现在回想起来,转载一下,方便查阅. 邮箱的广泛使用得益于它的免费,因此很多网站在注册的时候都会直接使用邮箱作为账号名 为了提高用户的体验,很多网站都会实现邮箱输入的自动提示功能. 实现效果如图所示: 核心代码(需要jquery的支持): (function($){ $.fn.mailAutoComplete = function(options){ var defaults = { boxClass: "

  • 基于jQuery的输入框无值自动显示指定数据的实现代码

    [解决方案] 1. 准备工作 (1)输入框 复制代码 代码如下: <input type="text" name="searchText" title="请输入搜索关键字" /> (2)CSS代码 复制代码 代码如下: input.helpText { color: #aaa;} (3)转换方法 复制代码 代码如下: function switchText() { if ($(this).val() == $(this).attr('

  • 基于jQuery的input输入框下拉提示层(自动邮箱后缀名)

    效果图 代码部分 复制代码 代码如下: // JavaScript Document (function($){ $.fn.extend({ "changeTips":function(value){ value = $.extend({ divTip:"" },value) var $this = $(this); var indexLi = 0; //点击document隐藏下拉层 $(document).click(function(event){ if($(

随机推荐