`
liuxiang822
  • 浏览: 47983 次
  • 性别: Icon_minigender_1
  • 来自: 常州
社区版块
存档分类
最新评论

jQuery 输入框下拉提示 仿百度(jquery autocomplete)

 
阅读更多

自动填充利用搜索和过滤,让用户快速找到并选择所需要的值。

当一个启动了自动填充功能的输入框得到焦点或者被输入值的时候,插件搜索匹配的选项并显示出来供用户选择。当输入更多的值的时候,可以得到更好的匹配结果。

这项功能可以用来输入刚刚选择的值,例如标签;或者输入一个地址、邮编,抑或从地址本里面输入邮件地址。

本地或者远程的数据都可作为自动填充的数据:当数据集较小的时候用本地数据比较好,例如具有 50 条数据左右的地址本;当数据量比较大的时候就需要远程数据了,比如要要从具有成千上万条的数据库中选择的时候。

下面就根据官方的文档一步一步地说明 jquery autocomplete 插件的用法:

官方文档的下载地址为: http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/

jQuery 官方 api 地址: http://docs.jquery.com/Plugins/Autocomplete

(一)        本地数据

解压之后在 jquery-autocomplete /demo/localdata.js 定义了 3 个数组, months, emails cities ,用来演示本地数据的自动填充。

 

函数签名:

autocomplete( url or data, [options] )

利用这个函数可以让一个输入框或者文本域是可以自动填充的。

第一个参数可以是一个远程数据的 URL ,也可以是本地数组。对于远程数据:当用户输入数据的时候,一个请求被发送到指定的后台程序 ( 比如 "my_autocomplete_backend.php") ,此请求包含两个 get 参数,一个名为“ q ”值为输入框的内容,一个为名为“ limit ”,值为配置选项中 max 的值。

如果输入的内容是 foo ,将会得到这样一个 URL

my_autocomplete_backend.php?q=foo&limit=10

结果必须一行返回一个值,结果的顺序将和后台返回的数据的顺序保持一致。

第二个参数是配置 autocomplete 的选项,参数形式为键值对,所有的选项都是可选的。

1.      自动填充本地数据,没有配置选项

首先来看最简单的 autocomplete ,来看文档例子的第一段:

<form autocomplete="off">

<p>

<label>Single City (local):</label>

         <input type="text" id="suggest1" />

         </p>

</form>

我们来看对应的 js

$().ready(function(){

         $("#suggest1").focus().autocomplete(cities);

});

其中 cities 被定义为 ["Aberdeen", "Ada", "Adamsville",…] 类型的数组。如此当往 id suggest1 的输入框输入内容的时候, cities 中的内容就会被过滤,匹配的内容显示在下方供选择。这里 autocomplete 只有一个参数,就是本地的数组。

2.      自动填充本地数据,有配置选项

带配置项的 autocomplete ,看文档例子的第二段(这里省去的外面的 form ):

<p>

                   <label>Month (local):</label>

                            <input type="text" id="month" />

                   </p>

         看对应的 js

$().ready(function(){

         $("#month").autocomplete(months, {

                   minChars: 0,

                   max: 12,

                   autoFill: true,

                   mustMatch: true,

                   matchContains: false,

                   scrollHeight: 220,

                   formatItem: function(data, i, total) {

                            // don't show the current month in the list of values (for whatever reason)

                            if ( data[0] == months[new Date().getMonth()] )

                                     return false;

                            return data[0];

                   }

         });});

         首先来看 months 的定义:

var months = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];

然后看配置选项:

1)   minChars (Number): 在触发autoComplete 前用户至少需要输入的字符数.Default: 1 ,如果设为0 ,在输入框内双击或者删除输入框内内容时显示列表

2)   max (Number):autoComplete 下拉显示项目的个数.Default: 10 ,由于月份只有12 个,这里定义为12

3)   autoFill (Boolean): 要不要在用户选择时自动将用户当前鼠标所在的值填入到输框.Default: false

4)   mustMatch (Booolean): 如果设置为true,autoComplete 只会允许匹配的结果出现在输入框, 所有当用户输入的是非法字符时将会得不到下拉框.Default: false

5)   matchContains (Boolean): 决定比较时是否要在字符串内部查看匹配,ba 是否与foo bar 中的ba 匹配. 使用缓存时比较重要. 不要和autofill 混用.Default: false

6)   scrollHeight (Number): 自动完成提示的卷轴高度用像素大小表示 Default: 180

7)   formatItem (Function): 为每个要显示的项目使用高级标签. 即对结果中的每一行都会调用这个函数, 返回值将用LI 元素包含显示在下拉列表中. Autocompleter 会提供4 个参数(row, i, max,value): 返回的结果数组, 当前处理的行数( 即第几个项目, 是从1 开始的自然数), 当前结果数组元素的个数即项目的个数, 最后一个是查询到的项. Default: none, 表示不指定自定义的处理函数, 这样下拉列表中的每一行只包含一个值.

这样就很容易可以看懂第二段了。

3.      自动填充本地数据,格式化显示和结果

配置项复杂的 autocomplete ,看文档例子的第三段:

<p>

         <label>E-Mail (local):</label>

         <input type="text" id="email" />

         <input type="button" value="Get Value" />

         </p>

对应的 js

         $("#email").autocomplete(emails, {

                   minChars: 0,

                   width: 310,

 

                   matchContains: "word",

                   autoFill: false,

                   formatItem: function(row, i, max) {

                            return i + "/" + max + ": \"" + row.name + "\" [" + row.to + "]";

                   },

                   formatMatch: function(row, i, max) {

                            return row.name + " " + row.to;

                   },

                   formatResult: function(row) {

                            return row.to;

                   }

         });

首先来看 emails 的定义:

var emails = [

         { name: "Peter Pan", to: "peter@pan.de" },

         { name: "Molly", to: "molly@yahoo.com" },

         { name: "Forneria Marconi", to: "live@japan.jp" },

         { name: "Master <em>Sync</em>", to: "205bw@samsung.com" },

         { name: "Dr. <strong>Tech</strong> de Log", to: "g15@logitech.com" },

         { name: "Don Corleone", to: "don@vegas.com" },

         { name: "Mc Chick", to: "info@donalds.org" },

         { name: "Donnie Darko", to: "dd@timeshift.info" },

         { name: "Quake The Net", to: "webmaster@quakenet.org" },

         { name: "Dr. Write", to: "write@writable.com" }

];

emails 的定义稍微复杂一些,可以看做数组的数组。

然后看配置选项:

1)         2 个选项和前面基本相同, matchContains 的配置和前面不同,这里的配置为“ word ”,即为 true ,表示可以是包含关系。 autoFill false 表示不自动把鼠标所在的行填充到输入框。

2)         formatItem 对返回结果的每一行做了处理。每一行都被处理成了这样的一种形式: i/max:”name”[to], 例如第一个被表示成: 1/10: "Peter Pan"[ peter@pan.de ]

3)         formatMatch 对每一行数据使用此函数格式化需要查询的数据格式 . 返回值是给内部搜索算法使用的 . 参数值和 formatItem 的参数一样。

4)         formatResult formatItem 类似 , 但可以将将要输入到 input 文本框内的值进行格式化 . 同样有三个参数 , formatItem 一样 .Default: none, 表示要么是只有数据 , 要么是使用 formatItem 提供的值 .

4.      自动填充本地数据,多项选择,用分隔符分隔

<p>

         <label>Tags (local):</label>

         <input type="text" id='tags' />

</p>

对应 js

$("#tags").autocomplete(["c++", "java", "php", "coldfusion", "javascript", "asp", "ruby", "python", "c", "scala", "groovy", "haskell", "pearl"], {

         width: 320,

         max: 4,

         highlight: false,

         multiple: true,

         multipleSeparator: " ",

         scroll: true,

         scrollHeight: 300

});

配置选项很简单,就是多了一个多项选择和分隔符。

5.      自动填充本地数据,弹出层( thickbox

<p>

         <a href="http://xianfengmc.blog.163.com/blog/#TB_inline?height=155&width=400&inlineId=modalWindow" class="thickbox">Click here for an autocomplete inside a thickbox window.</a> (this should work even if it is beyond the fold)

</p>         

<div id="modalWindow" style="display: none;">

         <p>

                   <label>E-Mail (local):</label>

                   <input type="text" id="thickboxEmail" />

                   <input type="button" value="Get Value" />

         </p>

</div>

对应 js

$("#thickboxEmail").autocomplete(emails, {

         minChars: 0,

         width: 310,

         matchContains: true,

         highlightItem: false,

         formatItem: function(row, i, max, term) {

                   return row.name.replace(new RegExp("(" + term + ")", "gi"), "<strong>$1</strong>") + "<br><span style='font-size: 80%;'>Email: &lt;" + row.to + "&gt;</span>";

         },

         formatResult: function(row) {

                   return row.to;

         }

});

当点击链接的时候弹出层,可以在弹出层中调用 autocomplete

(二)        远程数据 6.      自动填充远程数据,配置简单

从第四段开始就是取远程数据了,看第四段的 html

<p>

         <label>Single Bird (remote):</label>

         <input type="text" id="singleBirdRemote" />

</p>

对应的 js

$("#singleBirdRemote").autocomplete("search.php", {

         width: 260,

         selectFirst: false

});

由于远程取的是 php 文件,所以我首先搭建了一个 php 环境,用的是 Apache http 服务器,不会搭建的话随便百度一下。我是用的百度文库里的一片文章,如果你懒的话就用这个地址吧 http://wenku.baidu.com/view/ddc083c24028915f804dc2ff.html

首先让我们来看看 search.php ,里面都做了什么。

search.php 文件的一开始:

  <?php

$q = strtolower($_GET["q"]);

if (!$q) return;

$_GET() 方法获取 get 参数 q ,如果 q 为空则直接返回。然后定义了一个键值对的数据:

$items = array(

"Great <em>Bittern</em>"=>"Botaurus stellaris",

"Little <em>Grebe</em>"=>"Tachybaptus ruficollis",

"Black-necked Grebe"=>"Podiceps nigricollis",...);

文件的最后:

foreach ($items as $key=>$value) {

         if (strpos(strtolower($key), $q) !== false) {

                   echo "$key|$value\n";

         }

}

?>

foreach 循环数组里所有的元素,如果“键”里边包含所输入的值(查询的时候都把字母转化为了小写),则输出到页面。

其次,让我们分析一下 js

autocomplete 函数第一个参数是一个 url search.php ,刚才已经分析过 search.php 文件, search.php 把删选出来的数据返回给 autocomplete 用作自动填充的选项。第二个参数是配置选项,这里只给出了两个选项:第一个 width 不必多说,第二个 selectFirst: selectFirst (Boolean): 如果设置成 true, 在用户键入 tab return 键时 autoComplete 下拉列表的第一个值将被自动选择 , 尽管它没被手工选中 ( 用键盘或鼠标 ). 当然如果用户选中某个项目 , 那么就用用户选中的值 . Default: true

7.      自动填充远程数据,关键字包含,多项选择

之所以放在一块儿看,是因为这两段比较象,只是看不同的配置:

<p>

<label>Single City (contains):</label>

<input type="text" id="suggest14" />

</p>

<p>

         <label>Multiple Cities (local):</label>

         <textarea id='suggest3' cols='40' rows='3'></textarea>

</p>

对应的 js

$("#suggest14").autocomplete(cities, {

         matchContains: true,

         minChars: 0

});

$("#suggest3").autocomplete(cities, {

         multiple: true,

         mustMatch: true,

         autoFill: true

});

第六段的配置其实上边已经讲述,第七段多了一个配置选项 multiple: multiple (Boolean): 是否允许输入多个值即多次使用 autoComplete 以输入多个值 . Default: false.

8.      自动填充远程数据,用函数格式化显示和结果

<p>

         <label>Multiple Birds (remote):</label>

         <textarea id='suggest4'></textarea>

</p>

对应的 js

$("#suggest4").autocomplete('search.php', {

         width: 300,

         multiple: true,

         matchContains: true,

         formatItem: formatItem,

         formatResult: formatResult

});

取远程数据 search.php ,不过把 formatItem formatResult 分别指定了一个函数,这次我们需要看的只是这两个函数:

function formatItem(row) {

         return row[0] + " (<strong>id: " + row[1] + "</strong>)";

}

function formatResult(row) {

         return row[0].replace(/(<.+?>)/gi, '');

}

formatItem 函数对每一行进行了格式化, formatResult 函数去掉了其中的一些字符,如此而已。

9.      自动填充远程数据,列表中显示图片

<p>

         <label>Image search (remote):</label>

         <input type="text" id='imageSearch' />

</p>

对应的 js

$("#imageSearch").autocomplete("images.php", {

         width: 320,

         max: 4,

         highlight: false,

         scroll: true,

         scrollHeight: 300,

         formatItem: function(data, i, n, value) {

                  return "<img src='http://xianfengmc.blog.163.com/blog/images/" + value + "'/> " + value.split(".")[0];

         },

         formatResult: function(data, value) {

                  return value.split(".")[0];

         }

});

这次 autocomplete 函数请求的时候一个远程数据 images.php ,来看看 images.php 做了什么:

<?php

$term = $_REQUEST['q'];

$images = array_slice(scandir("images"), 2);

foreach($images as $value) {

         if( strpos(strtolower($value), $term) === 0 ) {

                   echo $value . "\n";

         }

}

?>

首先利用 $_REQUEST 得到参数 q ,赋值给 $item ,然后扫描 images 目录,返回文件名数组,并分隔数组,然后去搜索文件名,如果包含输入的值则返回文件名。

formatItem 函数首先根据查询到的文件名显示图片,然后输入文件名。

formatResult 只是显示文件名。

分享到:
评论

相关推荐

    jquery autocomplete下载.rar

    jQuery Autocomplete 是一个非常实用的插件,它为网页表单输入框提供了自动补全功能,极大地提升了用户体验。这个压缩包“jquery autocomplete下载.rar”包含了实现这一功能所需的基本文件,包括样式表、HTML 模板、...

    jquery.autocomplete.js资源压缩包下载

    1. **前端展示**:在用户输入时,`jquery.autocomplete.js`监听输入框的事件,如`keyup`或`input`,根据输入内容实时更新联想框。联想框通常是一个下拉列表,显示匹配的建议项。用户可以选择其中一个建议,或者继续...

    jquery.autocomplete.js使用示例,可直接运行

    jQuery Autocomplete.js 的工作原理是监听用户在输入框中的键盘事件,如keyup。当用户输入字符时,插件会发送Ajax请求到服务器,查询与输入内容匹配的数据。服务器返回结果后,插件会在输入框下方展示一个下拉列表,...

    jquery autocomplete

    jQuery Autocomplete 是一个非常流行的 jQuery 插件,它为输入框提供了自动补全的功能,极大地提升了用户在网站上的交互体验。这个插件源自于 jQuery UI 库,但也可以单独使用。在本文中,我们将深入探讨 jQuery ...

    输入框下拉提示

    在IT界,输入框下拉提示是一个常见的交互设计元素,主要应用于各种Web应用和桌面软件中,为用户提供方便快捷的数据选择。这种功能通常出现在搜索框、表单填写等场景,帮助用户快速找到并选择合适的选项,提高用户...

    jquery-autocomplete

    除了配置选项中的 `select` 和 `focus` 回调,`jQuery-autocomplete` 还提供了其他事件,如 `open`(下拉列表打开时)、`close`(下拉列表关闭时)和 `response`(服务器响应时),这些事件都可以用来进行更复杂的...

    jquery搜索自动提示下拉框插件autocomplete

    jQuery Autocomplete主要通过监听输入框的`keyup`事件来触发搜索建议的更新。当用户输入时,插件会根据输入的文本与数据源进行匹配,并通过筛选函数返回匹配的建议列表。这些匹配项随后会被渲染到下拉框中,供用户...

    php+jquery仿百度搜索提示框autoComplete

    "php+jquery仿百度搜索提示框autoComplete"是一个示例项目,它利用PHP和jQuery技术实现了类似百度搜索引擎的自动补全功能。这个功能允许用户在输入关键词时,系统会实时地根据已有的数据提供匹配的建议,从而加速...

    jQuery搜索框输入文字下拉提示菜单

    插件描述:jQuery搜索框提示,autocomplete输入框文字提示,搜索框提示文字,搜索框提示代码,搜索框提示功能.参考示例:http://www.jq22.com/jquery-info6193

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

    《jQuery实现Autocomplete插件:文本框下拉选项详解》 在Web开发中,用户界面的交互性与易用性是提升用户体验的关键因素之一。jQuery作为一个轻量级、功能强大的JavaScript库,为开发者提供了丰富的插件,使得创建...

    jquery autocomplete js 文件

    这个插件基于 jQuery 库,使得在网页中实现类似百度搜索框那样的动态下拉建议变得简单易行。在本篇文章中,我们将深入探讨如何使用和配置 jQuery Autocomplete 插件,以及其背后的核心概念。 ### 1. jQuery ...

    jQuery文本框联想补全自动完成插件

    jQuery文本框联想补全自动完成插件是一款非常实用的前端开发工具,它可以帮助开发者在网页的输入框中实现智能联想和自动补全功能。这个插件基于JavaScript库jQuery构建,因此,使用它之前需要确保项目中已经引入了...

    仿百度、Google搜索效果 AutoComplete

    仿百度、Google搜索效果的AutoComplete旨在提供与这两家知名搜索引擎类似的用户体验,即当用户在搜索框输入内容时,系统会实时分析并推荐相关的搜索建议,以下拉列表的形式呈现,帮助用户快速找到目标信息。...

    jquery autocomplete 动态补全例子有说明ajax加载

    jQuery Autocomplete是一款非常实用的JavaScript插件,它允许用户在输入框中输入文字时,根据已有的数据集动态提供补全建议。这个功能在许多Web应用中被广泛使用,如搜索框、表单输入等。在给定的“jquery ...

    Jquery AutoComplete

    `jQuery AutoComplete` 是一个非常流行的 JavaScript 库,它扩展了 jQuery UI 框架,为输入框提供自动补全功能。这个组件广泛应用于网页表单,尤其是在用户需要输入搜索关键词或者选择列表中的某一项时,能够极大地...

    jquery autoComplete

    `jQuery autoComplete` 是一个基于 jQuery 库的插件,它为网页表单输入框提供了自动完成的功能。这个插件能够帮助用户在输入时快速匹配并显示预先设定的数据集,通常用于提升用户体验,特别是在处理大量可选项或需要...

    jQuery自动补全自动提示插件仿百度自动提示插件

    **jQuery自动补全插件详解:仿百度自动提示功能** 在网页开发中,为了提高用户体验,经常需要实现一种类似于搜索引擎的自动补全功能,让用户在输入框中输入内容时能够实时得到相关的建议或提示。jQuery作为一款广泛...

    jquery的autocomplete(自动补全)插件

    **jQuery的Autocomplete插件**是用于实现网页输入框自动补全功能的一种高效解决方案,它极大地提升了用户体验,尤其是在用户需要从大量数据中选择时。这个插件是基于jQuery库的,因此,首先需要确保在项目中引入了...

    jQuery-Autocomplete-master.rar

    jQuery Autocomplete是一个非常实用的前端插件,它允许开发者为输入框添加自动补全功能,极大地提升了用户体验。这个"jQuery-Autocomplete-master"压缩包提供了一个简单的示例,用于演示如何利用jQuery实现自动补全...

    jquery.autocomplete js包

    - **实时搜索**:当用户在输入框中输入文本时,`jQuery Autocomplete` 可以实时检索与输入相匹配的数据,并展示在下拉列表中。 - **数据源**:数据可以来源于数组、JSON对象、远程API,或者通过函数动态生成,提供...

Global site tag (gtag.js) - Google Analytics