是Bootstrap-3-Typeahead,不是Twitter open source的typeahead,两者用法有差异。外加如果配合原生的Bootstrap3 的话推荐还是用这个。(当然Twitter open source也有个bootstrap)。

感觉这个简单功能够用了。

现在公司的项目中后台管理界面都开始用bootstrap 3 了,界面高大尚了很多,程序员就算不太会css也不用担心做的界面太丑了。

项目中要实现Jquery UI的autocomplete控件的功能,谷歌了一下,发现有个Typeahead, 写了几个demo,感觉功能还是挺不错的,记录分享一下。

常用参数说明

  1. source:是个function或者 基本类型的数组。
  2. items :下拉选项展示的个数
  3. afterSelect:选中之后执行的回调函数。

首先,当然是引用js文件。

<script src="~/Scripts/bootstrap3-typeahead.js"></script>

Demo1

Html:

  1. <div class="panel panel-default">
  2.     <div class="panel-heading">
  3.         <div class="panel-title">页面js 普通</div>
  4.     </div>
  5.     <div class="panel-body">
  6.         <div class="row">
  7.             <div class="col-md-4">
  8.                 @* autocomplete 避免浏览器的自动提示对下拉选项的覆盖操作 *@
  9.                 <input id="local_data" autocomplete="off" data-provide="typeahead" type="text" class="input-sm form-control" placeholder="请输入(本地Array数据)" />
  10.             </div>
  11.             <div class="col-md-4">
  12.                 <button class="btn btn-success" id="look_up_array">LookUp</button>
  13.                 <button class="btn btn-success" id="get_value_array">GetValue</button>
  14.             </div>
  15.         </div>
  16.     </div>
  17. </div>

Js:

  1. var localArrayData = ['beijing', 'shanghai', 'guangzhou', 'sz', 'hangzhou', 'ningbo'];
  2. function parseLocalArrayData() {
  3.             $("#local_data").typeahead({
  4.                 source: localArrayData,//数据源
  5.                 items: 8,//最多显示个数
  6.                 updater: function (item) {
  7.                     return item;//这里一定要return,否则选中不显示,外加调用display的时候null reference错误。
  8.                 },
  9.                 displayText: function (item) {
  10.                     return "选:" + item;//返回字符串
  11.                 },
  12.                 afterSelect: function (item) {
  13.                     //选择项之后的事件 ,item是当前选中的。
  14.                 },
  15.                 delay: 500//延迟时间
  16.             });
  17.             $("#look_up_array").click(function () {
  18.                 $("#local_data").typeahead("lookup", '选');
  19.             });
  20.             $("#get_value_array").click(function () {
  21.                 var val = $("#local_data").typeahead("getActive");
  22.                 console.log(val);
  23.             });
  24.         }

Demo2

Html:

  1. <div class="panel panel-default">
  2.     <div class="panel-heading">
  3.         <div class="panel-title">页面js Object数组</div>
  4.     </div>
  5.     <div class="panel-body">
  6.         <div class="row">
  7.             <div class="col-md-4">
  8.                 <input id="local_object_data" autocomplete="off" data-provide="typeahead" type="text" class="input-sm form-control" placeholder="请输入(本地Object数据)" />
  9.             </div>
  10.             <div class="col-md-4">
  11.                 <button class="btn btn-success" id="look_up_object">LookUP</button>
  12.                 <button class="btn btn-success" id="get_value_object">GetValue</button>
  13.             </div>
  14.         </div>
  15.     </div>
  16. </div>

Js:

  1. var localObjectData = [{ id: 1, name: 'beijing' }, { id: 2, name: 'shanghai' }, { id: 3, name: 'guangzhou' }, { id: 4, name: 'sz' }];
  2. var objMap = {};
  3. function parseLocalObjectData() {
  4.             //typeahead只能处理简单的列表,所以要构造一个array string。名称对应的id放到objMap里面;
  5.             $("#local_object_data").typeahead({
  6.                 source: function (query, process) {
  7.                     var names = [];
  8.                     $.each(localObjectData, function (index, ele) {
  9.                         objMap[ele.name] = ele.id;
  10.                         names.push(ele.name);
  11.                     });
  12.                     process(names);//调用处理函数,格式化
  13.                 },
  14.                 afterSelect: function (item) {
  15.                     console.log(objMap[item]);//取出选中项的值
  16.                 }
  17.             });
  18.         }

Demo3 异步调用服务器数据,delay参数就很有用了。

Html:

  1. <div class="panel panel-default">
  2.     <div class="panel-heading">
  3.         <div class="panel-title">向服务端获取list object数组 </div>
  4.     </div>
  5.     <div class="panel-body">
  6.         <div class="row">
  7.             <div class="col-md-4">
  8.                 <input id="remote_object_data" autocomplete="off" data-provide="typeahead" type="text" class="input-sm form-control" placeholder="请输入 (获取服务器的数据)" />
  9.             </div>
  10.             <div class="col-md-4">
  11.             </div>
  12.         </div>
  13.     </div>
  14. </div>

Js:

  1. var name2Id = {};//姓名对应的id
  2. function parseServerObjectArray() {
  3.             $("#remote_object_data").typeahead({
  4.                 source: function (query, process) {
  5.                     //query是输入的值
  6.                     $.post("@Url.Action("GetNames")", { name: query }, function (e) {
  7.                         if (e.success) {
  8.                             if (e.data.length == 0) { alert("没有查到对应的人"); return; }
  9.                             var array = [];
  10.                             $.each(e.data, function (index, ele) {
  11.                                 name2Id[ele.name] = ele.id;//键值对保存下来。
  12.                                 array.push(ele.name);
  13.                             });
  14.                             process(array);
  15.                         }
  16.                     });
  17.                 },
  18.                 items: 8,
  19.                 afterSelect: function (item) {
  20.                     console.log(name2Id[item]);//打印对应的id
  21.                 },
  22.                 delay: 500
  23.             });
  24.         }

Cs: mvc 的action,post提交,返回json

  1. [HttpPost]
  2.         public JsonResult GetNames(string name)
  3.         {
  4.             try {
  5.                 var rst = db.People
  6.                     .Where(w => (w.FirstName + w.LastName).Contains(name))
  7.                     .ToList()
  8.                     .Select(w => new { id = w.PersonID, name = String.Format("{0}-{1}", w.FirstName, w.LastName) });
  9.                 return Json(new { success = true, data = rst });
  10.             } catch(Exception ex) { return Json(new { success = false, msg = ex.Message }); }
  11.         }

介绍完毕。

过两天再整理一个datatables的文档。感觉功能很强大啊。

Bootstrap-3-Typeahead的更多相关文章

  1. 【Bootstrap】 typeahead自动补全

    typeahead 这篇文章记录了我在使用typeahead的一些问题,不是很全,但是基本够用. Bootstrap提供typeahead组件来完成自动补全功能. 两种用法: 直接给标签添加属性 &l ...

  2. 30 个惊艳的 Bootstrap 扩展插件

    Bootstrap 是快速开发Web应用程序的前端工具包.它是一个CSS和HTML的集合,它使用了最新的浏览器技术,给你的Web开发提供了时尚的版式,表单,buttons,表格,网格系统等等. Boo ...

  3. bootstrap-typeahead自动补充

    官方文档:https://github.com/bassjobsen/Bootstrap-3-Typeahead 这个是基于bootstrap的typeahead与基于jquery的jquery-Ty ...

  4. Bootstrap 中的 Typeahead 组件 -- AutoComplete

    Bootstrap 中的 Typeahead 组件就是通常所说的自动完成 AutoComplete,功能很强大,但是,使用上并不太方便.这里我们将介绍一下这个组件的使用. 第一,简单使用 首先,最简单 ...

  5. bootstrap - typeahead自动补全插件

    $('#Sale').typeahead({ ajax: { url: '@Url.Action("../Contract/GetSale")', //timeout: 300, ...

  6. Bootstrap Typeahead/Jquery autocomplete自动补全

    使用Bootstrap Typeahead 组件: Bootstrap 中的 Typeahead 组件就是通常所说的自动完成 AutoComplete,自动填充. 效果如图所示: 实现方式: 1.引入 ...

  7. 使用 Bootstrap Typeahead 组件

    Bootstrap 中的 Typeahead 组件就是通常所说的自动完成 AutoComplete,功能很强大,但是,使用上并不太方便.这里我们将介绍一下这个组件的使用. 第一,简单使用 首先,最简单 ...

  8. 使用升级版的 Bootstrap typeahead v1.2.2

    上次介绍了 Bootstrap 2 中附带的 typeahead,功能强大,但是使用起来不太方便,作者 Terry Rosen 已经升级了一个新版本 v1.2.2,作出了很大的改进. 下载地址 htt ...

  9. Bootstrap中的 Typeahead 组件

    Bootstrap 中的 Typeahead 组件其实就是嵌入到其中的typeahead.js插件,可以完成输入框的自动匹配功能,在通过一些人工的调整基本可以胜任所有的匹配功能和场景,下面介绍下简单的 ...

  10. BootStrap学习2 typeahead

    首先看看这些 http://www.wrapcode.com/bootstrap/typeahead-json-objects/ http://stackoverflow.com/questions/ ...

随机推荐

  1. VMware虚拟机Linux增加磁盘空间的扩容操作

    转载自点击打开链接 用VMwareware虚拟机安装的Red Hat Enterprise Linux系统剩余空间不足,造成软件无法正常安装.如果重新装一遍系统就需要重新配置好开发环境和软件的安装配置 ...

  2. eclipse中补齐代码的快捷键

    Shift+Alt+L比如我输入new TextView(this);按这个快捷键能自动生成TextView textView=new TextView(this); 例子: 代码将会变成如下:

  3. recyclerview刷新

    https://blog.csdn.net/leejizhou/article/details/51179233 RecyclerView之更新UI数据的高级用法 https://www.cnblog ...

  4. Thread,ThreadPool,Task

    线程分为前台和后台.比如我们直接new一个Thread这就是前台线程. 前台线程一定会执行. 比如我们创建2个线程:1号,2号,同时执行,假设1号是主线程,1执行完了,依旧会等待2执行完成,整个程序才 ...

  5. 下划线“_”在oracle中不是单纯的表示下划线的意思,而是表示匹配单一任何字符!

    [解决办法]1.使用 escape() 函数escape关键字经常用于使某些特殊字符,如通配符:'%','_'转义为它们原来的字符的意义,被定义的转义字符通常使用'\',但是也可以使用其他的符号.例如 ...

  6. 端口转发 Port Forwarding (一)

    0x00First 最近发现一些好用的端口转发工具和技巧,计划认真梳理一下 SSH.NC.LCX.EW.FRP 0x01 SSH隧道端口转发 目前利用SSH隧道(SSH tunneling)进行端口转 ...

  7. Maven中可以被继承的POM元素

    groupId:项目组ID,项目坐标的核心元素 version: 项目版本, 项目坐标的核心元素 description: 项目的描述信息 organization: 项目的组织信息 inceptio ...

  8. eclipse创建Maven web项目的步骤

    Maven 是一个项目管理工具,可以对 Java 项目进行构建.依赖管理. Maven 能够帮助开发者完成以下工作: 构建 文档生成 报告 依赖 SCMs 发布 分发 邮件列表 一.环境配置 Mave ...

  9. 微信小程序实现标签页滑块效果

    微信小程序实现标签页滑块效果 小程序完整代码: wxml: <view class="swiper-tab"> <view class="swiper- ...

  10. Robot Framework - 2 - 创建测试库

    04- 创建测试库--基础概念 Robot Framework 实际的测试能力是由测试库提供的. ***** 支持的编程语言 Robot Framework 自身是用 Python 编写的,能使用 P ...