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 相关文章推荐
JavaScript用Number方法实现string转int
May 13 Javascript
实例解析jQuery中如何取消后续执行内容
Dec 01 Javascript
微信小程序 常用工具类详解及实例
Feb 15 Javascript
详解探索 vuex 2.0 以及使用 vuejs 2.0 + vuex 2.0 构建记事本应用
Jun 16 Javascript
关于Vue实现组件信息的缓存问题
Aug 23 Javascript
jQuery md5加密插件jQuery.md5.js用法示例
Aug 24 jQuery
vue基于element的区间选择组件
Sep 07 Javascript
Vue函数式组件-你值得拥有
May 09 Javascript
简述vue-cli中chainWebpack的使用方法
Jul 30 Javascript
云服务器部署Node.js项目的方法步骤(小白系列)
Mar 23 Javascript
Vue+Spring Boot简单用户登录(附Demo)
Nov 12 Javascript
html中创建并调用vue组件的几种方法汇总
Nov 17 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
php实现mysql数据库操作类分享
2014/02/14 PHP
php利用scws实现mysql全文搜索功能的方法
2014/12/25 PHP
浅谈PHP中的
2016/04/23 PHP
基于Laravel 5.2 regex验证的正确写法
2019/09/29 PHP
跟着Jquery API学Jquery之一 选择器
2010/04/07 Javascript
js触发asp.net的Button的Onclick事件应用
2013/02/02 Javascript
javascript页面加载完执行事件代码
2014/02/11 Javascript
js表格排序实例分析(支持int,float,date,string四种数据类型)
2015/05/06 Javascript
Vue.js每天必学之数据双向绑定
2016/09/05 Javascript
touch.js 拖动、缩放、旋转 (鼠标手势)功能代码
2017/02/04 Javascript
微信小程序模板之分页滑动栏
2017/02/10 Javascript
VUE2实现事件驱动弹窗示例
2017/10/21 Javascript
在微信小程序中渲染HTML内容的方法示例
2018/09/28 Javascript
socket io与vue-cli的结合使用的示例代码
2018/11/01 Javascript
详解在网页上通过JS实现文本的语音朗读
2019/03/28 Javascript
JS原型与继承操作示例
2019/05/09 Javascript
Angular.JS读取数据库数据调用完整实例
2019/07/02 Javascript
JS实现简单省市二级联动
2019/11/27 Javascript
[32:47]完美世界DOTA2联赛 GXR vs IO 第二场 11.07
2020/11/09 DOTA
python自动化测试之从命令行运行测试用例with verbosity
2014/09/28 Python
教你用Type Hint提高Python程序开发效率
2016/08/08 Python
Python实现简单的四则运算计算器
2016/11/02 Python
python多线程socket编程之多客户端接入
2017/09/12 Python
Python网络编程详解
2017/10/31 Python
Python实现的径向基(RBF)神经网络示例
2018/02/06 Python
详解Numpy数组转置的三种方法T、transpose、swapaxes
2019/05/27 Python
对PyQt5基本窗口控件 QMainWindow的使用详解
2019/06/19 Python
Python实现初始化不同的变量类型为空值
2020/06/02 Python
解决Pyinstaller打包软件失败的一个坑
2021/03/04 Python
美国花布包包品牌:Vera Bradley
2017/08/11 全球购物
荷兰男士时尚网上商店:Suitable
2017/12/25 全球购物
Stefania Mode美国:奢华设计师和时尚服装
2018/01/07 全球购物
班主任与学生安全责任书
2014/07/25 职场文书
网络营销实训总结
2015/08/03 职场文书
Golang中异常处理机制详解
2021/06/08 Golang
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/07 其他游戏