基于Bootstrap的下拉框插件bootstrap-select
写在前面:
在这次的项目中,没有再使用liger-ui做为前端框架了,改为了Bootstrap,这次也好接触下新的技术,在学习的过程中发现,Bootstrap的一些组件基本都是采用class的形式,就是给一个它定义好的样式,就会给你展现出一个好看的组件出来,这个比liger-ui的界面做的要好,但是了解了Boostrap的基本语法后,发现在官方的文档中,并没有一些可以动态加载组件的demo,因为之前用的liger-ui,大多数组件都只需要写一行代码,就能很好的,并且很方便的直接与后台进行交互,并动态加载数据。但是bootstrap的文档中并没有这样的例子。毕竟它就是做静态的,只需要给一个样式,那我动态加载数据怎么办?全部自己封装吗?后面查阅资料发现,有许多常用的组件插件是基于bootstrap来进行封装的,这就需要我们如果要使用什么组件,可以单独的再去下载它的插件。这个时候,就可以做到很方便的像后台发送数据进行动态加载了。这里就记录下,一些常用的bootstrap的组件插件吧,首先是下拉框
基于Bootstrap的下拉框也有好几个,这里我选择了bootstrap-select.js.下面就简单的记录下它的用法吧,主要是动态的加载数据。
首先还是上代码,毕竟代码最直观。
前台jsp页面:
- <%@ page contentType="text/html;charset=UTF-8" language="java" %>
- <%
- String scheme = request.getScheme();
- String serverName = request.getServerName();
- String contextPath = request.getContextPath();
- int port = request.getServerPort();
- //网站的访问跟路径
- String baseURL = scheme + "://" + serverName + ":" + port
- + contextPath;
- request.setAttribute("baseURL", baseURL);
- System.out.println("baseURL:" + baseURL);
- %>
- <html>
- <head>
- <meta name="viewport" content="width=device-width" />
- <title>bootstrap-select测试</title>
- <%--导入bootstrap与select样式--%>
- <link rel="stylesheet" type="text/css" href="${baseURL}/Bootstrap/bootstrap/css/bootstrap.min.css" />
- <link href="${baseURL}/Bootstrap/bootstrap-select/css/bootstrap-select.css" rel="stylesheet" />
- <%--先导入jqury插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap/assets/js/jquery-1.10.2.min.js"></script>
- <%--导入bootstrap插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap/assets/js/bootstrap.min.js"></script>
- <%--下拉框插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap-select/js/bootstrap-select.js"></script>
- </head>
- <body>
- <label style="font-weight:normal;background-color: #fac090;width: 80px;text-align: center" >Role</label>
- <%--给一个class=“selectpicker” 改变下拉框的宽度用data-width --%>
- <select id="sel_role" name="role" class="selectpicker" title="请选择" data-width="150px" style="">
- </select>
- </body>
- <script>
- $(function(){
- //初始化下拉框
- //动态加载
- $.ajax({
- type: 'get',
- url: '${baseURL}/listAllRole',
- dataType: "json",
- success: function (data) {
- //拼接下拉框
- for(var i=0;i<data.length;i++){
- $("#sel_role").append("<option value='"+data[i].roleId+"'>"+data[i].roleName+"</option>");
- }
- //这一步不要忘记 不然下拉框没有数据
- $("#sel_role").selectpicker("refresh");
- }
- });
- });
- </script>
- </html>
首先要导入相关的样式以及js插件,由于bootstrap是基于jquery的,故要先导入jquery插件,然后bootstrap-select又是基于bootstrap的。故先导入bootstrap,再导入bootstrap-select.这里要注意下导入的顺序呢。
对于动态的加载数据,还是要自己进行拼接,然后refresh一下,这个一定不能忘记,不然不会出来数据。由于此次的后台还是ssh框架,故后台查询下拉框的数据,并如何返回json给前台页面,这里就不再详细的说了,之前在ligerui博文中都有写过,并提及过。
看下效果图吧:
除了常用的单个下拉框外,还有最常见的就是下拉框级联了,这里也写个demo来记录一下,代码如下,也是只上前台jsp页面的代码,后台json数据的传递就不再说了。
- <%@ page contentType="text/html;charset=UTF-8" language="java" %>
- <%
- String scheme = request.getScheme();
- String serverName = request.getServerName();
- String contextPath = request.getContextPath();
- int port = request.getServerPort();
- //网站的访问跟路径
- String baseURL = scheme + "://" + serverName + ":" + port
- + contextPath;
- request.setAttribute("baseURL", baseURL);
- System.out.println("baseURL:" + baseURL);
- %>
- <html>
- <head>
- <meta name="viewport" content="width=device-width" />
- <title>bootstrap-select测试</title>
- <%--导入bootstrap与select样式--%>
- <link rel="stylesheet" type="text/css" href="${baseURL}/Bootstrap/bootstrap/css/bootstrap.min.css" />
- <link href="${baseURL}/Bootstrap/bootstrap-select/css/bootstrap-select.css" rel="stylesheet" />
- <%--先导入jqury插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap/assets/js/jquery-1.10.2.min.js"></script>
- <%--导入bootstrap插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap/assets/js/bootstrap.min.js"></script>
- <%--下拉框插件--%>
- <script src="${baseURL}/Bootstrap/bootstrap-select/js/bootstrap-select.js"></script>
- </head>
- <body>
- <label style="font-weight:normal;background-color: #fac090;width: 80px;text-align: center" >Biz Unit</label>
- <select id="sel_bizUnit" name="bUnitId" class="selectpicker" title="请选择" data-width="150px" style="">
- </select>
-
- <label style="font-weight:normal;background-color: #fac090;width: 80px;text-align: center" >Division</label>
- <select id="sel_division" name="divId" class="selectpicker"title="请选择" data-width="150px" style="">
- </select>
- </body>
- <script>
- $(function(){
- //初始化下一级下拉框
- //动态加载
- $.ajax({
- type: 'get',
- url: '${baseURL}/listAllSABusinessUnit',
- dataType: "json",
- success: function (data) {
- for(var i=0;i<data.length;i++){
- $("#sel_bizUnit").append("<option value='"+data[i].bUnitId+"'>"+data[i].bUnitName+"</option>");
- }
- $("#sel_bizUnit").selectpicker("refresh");
- }
- });
- //二级下拉框的选项随一级下拉框的值而改变
- $("#sel_bizUnit").change(function(){
- //根据bUnit去获取Division
- $.ajax({
- type: 'get',
- url: '${baseURL}/getSADivisionByBUnit?bUnitId='+$("#sel_bizUnit").val(),
- dataType: "json",
- success: function (data) {
- if(data.length == 0){
- //如果一级没有对应的二级 则清空二级并 不往下执行
- $("#sel_division").empty();
- $("#sel_division").selectpicker("refresh");
- return ;
- }
- //如果一级有对应的二级 则进行拼接
- //每次拼接前都进行清空
- $("#sel_division").empty();
- for(var i=0;i<data.length;i++){
- $("#sel_division").append("<option value='"+data[i].divId+"'>"+data[i].divName+"</option>");
- }
- //这里千万别忘记了
- $("#sel_division").selectpicker("refresh");
- }
- });
- });
- });
- </script>
- </html>
代码都比较简单,基本看下就会了,也就是根据一级下拉框的值去查询获取对应的二级下拉框的值,然后拼接加载出来就完事了。值得注意的点,当一级没有对应的二级时,此时也应该将二级清空并refresh一下,不然当第一次勾选一级a,对应有二级,接着再次选择一级b,没有对应的二级时,还是会显示出一级a对应的二级。所以这个时候也应该清空一下。这些小细节可以按照自己的项目需求来。好了,完事了。
看下效果图:
基于Bootstrap的下拉框插件bootstrap-select的更多相关文章
- Dropdown.js基于jQuery开发的轻量级下拉框插件
Dropdown.js 前言 在SPA(Single Page Application)盛行的时代,jQuery插件的轮子正在减少,由于我厂有需求而开发了这个插件.如果觉得本文对您有帮助,请给个赞,以 ...
- jQuery自定义漂亮的下拉框插件8种效果演示
原始的下拉框不好看这里推荐一个jQuery自定义漂亮的下拉框插件8种效果演示 在线预览 下载地址 实例代码 <!DOCTYPE html> <html lang="en&q ...
- jQuery下拉框插件8种效果
jQuery自定义漂亮的下拉框插件8种效果 jquery美化选择器实例有:边框.下划线. 伸缩 .滑动. 覆盖. 旋转. 弹出层选择 .环形效果. 在线预览 <body class=" ...
- query多选下拉框插件 jquery-multiselect(修改)
其实网上关于该控件的使用教程已经很多了,其中 query多选下拉框插件 jquery-multiselect Jquery多选下拉列表插件jquery multiselect功能介绍及使用 这2个的介 ...
- jquery 获取下拉框值与select text
下面先介绍了很多jquery获取select属性的方法,同时后面的实例我们讲的是jquery 获取下拉框值与select text代码. 下面先介绍了很多jquery获取select属性的方法,同时后 ...
- 浅解bootstrap 下拉框插件
最近的业务需求是把后台数据渲染到前端,其中有一个是复选框数组,前端选择渲染的方式是bootstrap的下拉插件 渲染完成之后,此时会在原有select同级上面生成buton,dropdown-menu ...
- Bootstrap selectpicker 下拉框多选获取选中value和多选获取文本值
1.页面代码: 页面引入: bootstrap-select.min.css和 bootstrap-select.min.js. defaults-zh_CN.min.js文件,并初始化下拉选项框. ...
- jQuery无限级联下拉框插件
自己编写jQuery插件 之 无限级联下拉框 因为是级联,所以数据必须是树型结构的,我这里的测试数据如下: 看下效果图: 1.>图一: 2.>图二: 3.>图三: 由图可知,下拉 ...
- select下拉框插件jquery.editable-select
项目中有个需求,下拉框既可以下拉选择,也可以手动填写 html代码 <span>数据来源</span> </select> js代码 $('#noMean').ed ...
随机推荐
- freemaker示例
第一步 创建一个User.java文件 来两个变量 public class User { private String userName; private String us ...
- 1106 Lowest Price in Supply Chain (25 分)(树的遍历)
求叶子结点处能活得最低价格以及能提供最低价格的叶子结点的个数 #include<bits/stdc++.h> using namespace std; ; vector<int> ...
- 先立一个书单【flag】,敦促自己温故知新
书单来源david mimno副教授给ML新生的建议博文,外加一部分搜罗的书籍 学习方式:以书籍查看,习题为辅,代码为最终实现方式,分主题进行今年的学习笔记,立此旗为证. 线代 --> 概率统计 ...
- java课后作业2017.10.20
动手动脑1: public class Test{ public static void main(String args[]) { Foo obj1=new Foo(); }}class Foo{ ...
- ocrosoft Contest1316 - 信奥编程之路~~~~~第三关 问题 L: 大整数减法
http://acm.ocrosoft.com/problem.php?cid=1316&pid=11 题目描述 求两个大的正整数相减的差. 输入 共2行,第1行是被减数a,第2行是减数b ...
- hdu1007 平面最近点对(暴力+双线程优化)
突发奇想,用双线程似乎可以优化一些暴力 比如说平面最近点对这个题目,把点复制成2份 一份按照x排序,一份按照y排序 然后双线程暴力处理,一份处理x,一份处理y 如果数据利用x递减来卡,那么由于双线程, ...
- SecureCRT配置设置
颜色设置 参考: http://blog.csdn.net/zklth/article/details/8937905 配置导入.导出 参考: http://jingyan.baidu.com ...
- 2015年4月1日 14:36:56 EF 主从表更新
公司封装框架的人把eF封在了工作单元里面,使用了Unitofwork这样的形式, 我用代码生成器生成了基础的单表操作的代码. 这种方式对多表有问题. 暂时只得,一张表一张表地操作, 我采用先用List ...
- Spring中报"Could not resolve placeholder"的解决方案(引入多个properties文件)
除去properites文件路径错误.拼写错误外,出现"Could not resolve placeholder"很有可能是使用了多个PropertyPlaceholderCon ...
- cygwin设置
解决乱码问题 # 设置为中文环境,使提示成为中文 export LANG =" zh_CN.UTF-8 " # 输出为中文编码 export OUTPUT_CHARSET =& ...