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 相关文章推荐
JS 继承实例分析
Nov 04 Javascript
JavaScript中instanceof与typeof运算符的用法及区别详细解析
Nov 19 Javascript
纯JS代码实现气泡效果
May 04 Javascript
详解用node.js实现简单的反向代理
Jun 26 Javascript
Angular 4中如何显示内容的CSS样式示例代码
Nov 06 Javascript
Layer弹出层动态获取数据的方法
Aug 20 Javascript
浅谈vux之x-input使用以及源码解读
Nov 04 Javascript
详解如何模拟实现node中的Events模块(通俗易懂版)
Apr 15 Javascript
vue中使用vue-cli接入融云实现即时通信
Apr 19 Javascript
基于Node.js的大文件分片上传示例
Jun 19 Javascript
vue仿ios列表左划删除
Sep 26 Javascript
基于JavaScript实现轮播图效果
Jan 02 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_real_escape_string函数用法与实例教程
2013/09/30 PHP
PHP中4个加速、缓存扩展的区别和选用建议
2014/03/12 PHP
php使用MySQL保存session会话的方法
2015/06/26 PHP
php将数组存储为文本文件方法汇总
2015/10/28 PHP
PHP聚合式迭代器接口IteratorAggregate用法分析
2017/12/28 PHP
Javascript中的变量使用说明
2010/05/18 Javascript
javascript event 事件解析
2011/01/31 Javascript
模拟jQuery中的ready方法及实现按需加载css,js实例代码
2013/09/27 Javascript
调试代码导致IE出错的避免方法
2014/04/04 Javascript
Node.js与Sails ~项目结构与Mvc实现及日志机制
2015/10/14 Javascript
jQuery EasyUi实战教程之布局篇
2016/01/26 Javascript
javaScript基础详解
2017/01/19 Javascript
JS+HTML5实现上传图片预览效果完整实例【测试可用】
2017/04/20 Javascript
vue组件实现进度条效果
2018/06/06 Javascript
js数组去重的方法总结
2019/01/18 Javascript
js中Generator函数的深入讲解
2019/04/07 Javascript
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
python对指定目录下文件进行批量重命名的方法
2015/04/18 Python
python中如何使用正则表达式的集合字符示例
2017/10/09 Python
python 动态加载的实现方法
2017/12/22 Python
Python通过Pygame绘制移动的矩形实例代码
2018/01/03 Python
python多线程调用exit无法退出的解决方法
2019/02/18 Python
Python地图绘制实操详解
2019/03/04 Python
浅谈pandas.cut与pandas.qcut的使用方法及区别
2020/03/03 Python
执行Python程序时模块报错问题
2020/03/26 Python
使用CSS3的box-sizing属性解决div宽高被内边距撑开的问题
2016/06/28 HTML / CSS
瑜伽灵感珠宝:Satya Jewelry
2018/01/06 全球购物
我的大学生活职业生涯规划
2014/01/02 职场文书
九年级物理教学反思
2014/01/29 职场文书
政府门卫岗位职责
2014/04/29 职场文书
经典演讲稿开场白
2014/08/25 职场文书
中秋节国旗下演讲稿
2014/09/13 职场文书
社区活动总结范文
2015/05/07 职场文书
入团介绍人意见范文
2015/06/04 职场文书
虚拟机linux端mysql数据库无法远程访问的解决办法
2021/05/26 MySQL
Vue.Draggable实现交换位置
2022/04/07 Vue.js