bootstrap select下拉搜索插件使用方法详解


Posted in Javascript onNovember 23, 2017

bootstrap-select是boot的下拉搜索插件,使用的时候有时我们需要动态从后台 或者 直接加载动态数据。
下面是根据一级下拉菜单,动态加载二级联动方式。(不是ajax后台获取)

首先引入js与css文件(一个css两个js)

<link rel="stylesheet" href="css/bootstrap-select.css" rel="external nofollow" >

js省略

一、下拉搜索(html)

<select class="selectpicker" data-live-search="true" id="d1">
  <option value="-1">请选择</option>
  <option value="0">0</option>
  <option value="1">1</option>
  <option value="2">2</option>
  <option value="3">3</option>
</select>
<select class="selectpicker" data-live-search="true" id="d2">
  <option value="-1">请选择</option>
</select>

二、加载数据 二级联动(js)

function smallScreen(){   // 个人项目中间距处理,可以省略
  if($(window).width()<768){
    $('.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(.input-group-btn)').css({
      'width':'100%',
      'margin-top':'10px'
    });
  }
}
$(function(){
var erji=[
    ['海淀区','东城区','西城区'], // 0
    ['浦东区','金山区','黄埔区'], // 1
    ['台州市','杭州市','宁波市','嘉兴市'], // 2
    ['郑州市','洛阳市','开封市'] // 3
  ];
  var yuan = '<li data-original-index="-1" class>' +   // 字符串拼接
      '<a tabindex="0" data-tokens="null" role="option" aria-disabled="false" aria-selected="false">' +
      '<span class="text">请选择</span>' +
      '<span class="glyphicon glyphicon-ok check-mark"></span>' +
      '</a>' +
      '</li>';
  $('#d1').change(function(){  // 一级下拉菜单选项改变事件
    if($(this).val() === '-1'){
      $('#d2').prev('div.dropdown-menu').find('ul').html(yuan);
      $('#d2').html('<option>请选择</option>');
      $('.selectpicker').selectpicker('refresh');
      smallScreen();
      return;
    }
    var cityIndex = erji[ this.value ]; // 当前下标在二级对应内容
    var html = '<li data-original-index="-1" class>' +   // 下拉搜索动态加载成的标签
        '<a tabindex="0" data-tokens="null" role="option" aria-disabled="false" aria-selected="false">' +
        '<span class="text">请选择</span>' +
        '<span class="glyphicon glyphicon-ok check-mark"></span>' +
        '</a>' +
        '</li>';
    var erjiOption = '<option value="0">请选择</option>';  // 同事添加option
    for(var i = 0;i<cityIndex.length;i++){
      html+= '<li data-original-index='+i+'>' +
          '<a tabindex="0" data-tokens="null" role="option" aria-disabled="false" aria-selected="false">' +
          '<span class="text">'+cityIndex[i]+'</span>' +
          '<span class="glyphicon glyphicon-ok check-mark"></span>' +
          '</a>' +
          '</li>';  // 此处为了兼容ie,采用的字符串拼接而不是ES6的模板字符串。
      // 添加option
      erjiOption += '<option value='+i+'>'+cityIndex[i]+'</option>';
    }
    $('#d2').prev('div.dropdown-menu').find('ul').html(html);
    $('#d2').html(erjiOption);
    $('.selectpicker').selectpicker('refresh');
    smallScreen();
  });
});
});

个人使用有效。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
List the Codec Files on a Computer
Jun 18 Javascript
用javascript实现点击链接弹出&quot;图片另存为&quot;而不是直接打开
Aug 15 Javascript
javascript+xml实现简单图片轮换(只支持IE)
Dec 23 Javascript
jquery自定义滚动条插件示例分享
Feb 21 Javascript
JS实现灵巧的下拉导航效果代码
Aug 25 Javascript
基于JS2Image实现圣诞树代码
Dec 24 Javascript
Dojo获取下拉框的文本和值实例代码
May 27 Javascript
浅谈JS运算符&amp;&amp;和|| 及其优先级
Aug 10 Javascript
微信小程序获取用户openId的实现方法
May 23 Javascript
实现两个文本框同时输入的实例
Sep 25 Javascript
JS实现DOM删除节点操作示例
Apr 04 Javascript
Vue项目环境搭建详细总结
Sep 26 Javascript
基于Bootstrap实现城市三级联动
Nov 23 #Javascript
bootstrap-Treeview实现级联勾选
Nov 23 #Javascript
基于vue-cli创建的项目的目录结构及说明介绍
Nov 23 #Javascript
sublime text配置node.js调试(图文教程)
Nov 23 #Javascript
Vue代码分割懒加载的实现方法
Nov 23 #Javascript
初探js和简单隐藏效果的实例
Nov 23 #Javascript
详解如何在angular2中获取节点
Nov 23 #Javascript
You might like
IIS环境下快速安装、配置和调试PHP5.2.0
2006/12/17 PHP
php2html php生成静态页函数
2008/12/08 PHP
PHP实现图片压缩的两则实例
2014/07/19 PHP
php中的字符编码转换函数用法示例
2014/10/20 PHP
header与缓冲区之间的深层次分析
2016/07/30 PHP
一个实用的php验证码类
2017/07/06 PHP
HTML5如何适配 iPhone IOS 底部黑条
2021/03/09 HTML / CSS
JavaScript 参考教程
2006/12/29 Javascript
Eval and new funciton not the same thing
2012/12/27 Javascript
Js中setTimeout()和setInterval() 何时被调用执行的用法
2013/04/12 Javascript
JS操作select下拉框动态变动(创建/删除/获取)
2013/06/02 Javascript
js 控制图片大小核心讲解
2013/10/09 Javascript
javascript继承的六大模式小结
2015/04/13 Javascript
JavaScript常见的五种数组去重的方式
2016/12/15 Javascript
echarts3 使用总结(绘制各种图表,地图)
2017/01/05 Javascript
Vue使用vue-area-linkage实现地址三级联动效果的示例
2018/06/27 Javascript
判断js数据类型的函数实例详解
2019/05/23 Javascript
微信小程序修改checkbox的样式代码实例
2020/01/21 Javascript
Python3实现将文件归档到zip文件及从zip文件中读取数据的方法
2015/05/22 Python
使用11行Python代码盗取了室友的U盘内容
2018/10/23 Python
Python 一句话生成字母表的方法
2019/01/02 Python
Django之无名分组和有名分组的实现
2019/04/16 Python
python 读写excel文件操作示例【附源码下载】
2019/06/19 Python
日本小田急百货官网:Odakyu
2018/07/19 全球购物
EM Cosmetics官网:由彩妆大神Michelle Phan创办的独立品牌
2020/04/27 全球购物
如何写一个Java类既可以用作applet也可以用作java应用
2016/01/18 面试题
银行毕业实习自我鉴定
2013/09/19 职场文书
应聘自荐书
2013/10/08 职场文书
人事部专员岗位职责
2014/03/04 职场文书
中学生评语大全
2014/04/18 职场文书
消防宣传口号
2014/06/16 职场文书
学习考察心得体会
2014/09/04 职场文书
先进班组事迹材料
2014/12/25 职场文书
2015年教师节慰问信
2015/03/23 职场文书
导游词之京东大峡谷旅游区
2019/10/29 职场文书
nginx刷新页面出现404解决方案(亲测有效)
2022/03/18 Servers