JQuery 常用积累(四)Bootstrap Multiselect

阅读目录

     实际的项目网站中或多或少的或用到多选框,我选用的一款是Bootstrap Multiselect。

官方文档:

http://www.kuitao8.com/demo/20140224/1/bootstrap-multiselect-master/index.html

如果你英文好一点,里面有详细的介绍,多选框的设置,多选框获取值/文本,选项分组,各种各样丰富的表现方式和获取.......

  

    结合实际项目,加深技术理解,同时也方便自己后续项目中的使用。

    多选框和单选框相同,实际项目中前端不可能将里面的选项很直白的写在展示层面,或多都是取自数据库中的代码表。

    这样耦合低,便于维护;当需要展示的选项发生变化的时候,只需要变更一遍数据库就好,不需要每个页面修改,假如有100个页面放置了单选框或者多选框,画面太惨了......

    动态生成 多选框/单选框 方式我接触的写法有两种,具体好坏,效率问题,仁者见仁智者见智。

    程序设计方式多种多样,看客老爷肯定知道比我这样写更好的,不多说了,上代码。

回到顶部

1.JavaBean 方式,在JSP 页面,嵌入java 代码实现

               <div class="input-append">
                    <span class="add-on">bootstrapMultiselect</span><select class="multiselect" multiple="multiple">
                    <%  for(int i=0;i<list.size();i++){
                        Product product = list.get(i);
                        //System.out.println(product.toString());
                    %>
                    <option value='<%=product.getId() %>'><%=product.getName() %></option>
                    <% } %>
                    </select>
                </div>

a.product 定义的基本的属性和 setter 和 getter 是一个纯粹的 pojo 对象;

b.具体的 product 对象的读取,涉及与数据交互,封装方法的数据结构可以使用很多(包括数组、map、list),我这里使用的是 ArrayList<Product>;

c.如果想实现的更合理一点,可以定义数据库访问接口,里面定义各种各样对操作 product 的方法(增,删,改,查....),然后由另外一个类实现这些接口的方法(貌似扯远了,等有时间在说吧);

回到顶部

2.后台数据库交互,前台 JavaScript 动态添加选项

  依赖的具体的 WebMVC 框架为 SpringMvc.

  前台 ajax 请求以及动态生成选项:

  $.ajax({
      url : "/" + window.location.pathname.split("/")[1] + '/service/product/init',
      type : 'POST',
      dataType : 'json',
      success : function(data) {
          if (data.success) {
              /**
               * Bootstrap Multiselect 动态赋值选项卡 1
               */
              var products = data.products;
              $.each(products, function(index, product) {
                  $("#product").append('<option value="' + product.id + '">' + product.name + '</option>');
              });

              /**
               * Bootstrap Multiselect 动态赋值选项卡 2
               */
              var products = data.products;
              var newProducts = new Array();
              var obj = new Object();
              $.each(products, function(index, product) {
                  obj = {
                      label : product.id,
                      value : product.name
                  };
                  newProducts.push(obj);
              });
               $(".multiselect").multiselect('dataprovider', newProducts);
          }
      }
  });

 a. 第一种方法去赋值时需要注意的时,多选框要在前面先初始化;

 b. 然后在官方文档的帮助下,找到了第二种方法,需要用到一个 Array,还有一个万能的 object,将后台返回回来的数据封装给object ,然后将object 放入 Array中,最后赋值给多选框;

 c. 后台交互需要一个简单的 sql ,SpringMvc 会将返回回去的 map,转换为 javascript Object 对象, list 转换为 Array 对象;

 d.多选框提交到后台值,你可以选择提交选项文本,选项对应的值,提交选项 code 有优势,具体为code 一般为数字或者字母,而文本一般是汉字,会导致post 到后台的内容过大,需要进行转码,code 在代码表中是唯一的,还有安全性较高;

 e.后台具体的解析方法如下,我项目中具体是进行查询,所以拼接为一个 sql 子句,解析后当然也可以用来更新数据库;

                if(!cxxxjo.getString("product").equals("null") && cxxxjo.getString("product").length() > 0){
                    JSONArray productja = JSONArray.fromObject(cxxxjo.getString("product"));
                        wherestr += " and t.product in(";
                        for(int i = 0;i < productja.size();i++){
                            if(i == productja.size()-1){
                                wherestr += "'" + productja.get(i).toString()+"'";
                            }else{
                                wherestr += "'" + productja.get(i).toString()+"',";
                            }
                        }
                        wherestr+=")";
                }

作者:Orson 
出处:http://www.cnblogs.com/java-class/ 
如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】 
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】 
如果,您对我的博客内容感兴趣,请继续关注我的后续博客,我是【Orson】 

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段 声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 

转载:http://www.cnblogs.com/java-class/p/4680255.html

时间: 2024-09-19 09:24:57

JQuery 常用积累(四)Bootstrap Multiselect的相关文章

JQuery 常用积累(二)Pagination 分页组件

阅读目录 1.JSP页面 2.JS 控制 3.后台java类进行处理的两个公共方法 官方Demo网址:http://mricle.com/JqueryPagination      分页组件几乎是一般网站都会涉及到的组件,网上有很多这样的插件,自己挑来跳去选择了这一款,功能强大,可扩展性比较强,而且幕后的工程师一直在完善这个插件,不废话了,上干货. (模拟场景:商店网站,俺要根据用户选择的查询条件,来查询数据库,并展示到前台) 回到顶部 1.JSP页面 如果你的web项目前台是基于bootstr

JQuery 常用积累(六)ZTree

阅读目录 1. Ztree 主要的特点 2. Web 前端 3. Web 后端     Web 项目或多或少都会有涉及到什么人员职称树,菜单树,组织机构树......     历手三四个项目有大有小,采用的树前端都是 Ztree.     有些优秀的J2EE 框架将这些常用的组件都封装起来,作为模块化的组件提供给前端,这样固然是好,开发效率会提升几倍.     客户需求是什么,组件化往上一套,几分钟就能搭建起来.     但这样咱程序员真的就是搬砖的了,纯纯的重复性工作. 回到顶部 1. Ztr

JQuery 常用积累(一)前后台数据交互和处理

1. 遍历表格中的所勾选的行,组织数据结构,传递到后台处理: var datas = new Object(); var fields = ["致命",连击","连击次","命中","混乱","封印","遗忘","鬼火"]; $("#table").find("tr").each(function(i) { //这一句

JQuery 常用积累(三)Select 下拉框

阅读目录 1.jQuery获取Select选择的Text和Value 2.jQuery设置Select选择的Text和Value 3.jQuery添加/删除Select的Option项 4.遍历option和添加.移除option <select id="hello"></select> 回到顶部 1.jQuery获取Select选择的Text和Value 语法解释: $("#select_id").change(function(){//c

JQuery 常用积累(五)Datetimepicker和Lodop

阅读目录 1.Datetimepicker 2.Lodop web项目中日期选择器和打印这两个功能是非常常见,将项目中使用的日期选择器和打印控件,在这里总结归纳,为方便后面使用. 回到顶部 1.Datetimepicker a.官方API:http://www.bootcss.com/p/bootstrap-datetimepicker/ 里面有详细的Datetimepicker介绍,包括支持的方法.设置的选项.事件..... b.项目集成Datetimepicker实例:    这是一款依赖与

JS组件系列——两种bootstrap multiselect组件大比拼

原文:JS组件系列--两种bootstrap multiselect组件大比拼 前言:今天继续来看看bootstrap的另一个组件:multiselect.记得在项目开始之前,博主项目组几个同事就使用哪些js组件展开过讨论,其中就说到了select组件,由于项目的整体风格使用的bootstrap风格,所以在选用select组件的时候优先考虑和bootstrap结合使用的.其中就找到了两个这种组件,大体样式和功能基本相同,经过一番讨论,项目组决定使用davidstutz的bootstrap-mul

jQuery常用知识点总结以及平时封装常用函数_jquery

本文为大家介绍了jQuery中常用知识点及函数,包含许多细节方面的知识,下面我们一起学习一下. jQuery中为我们提供了很多有用的属性,自己总结的一些常用的函数.个人认为在在线排盘开发中会比较常用的,仅供大家学习和参考. 刚开始学习前端的时候开始整理这个文档,现在内容已经逐渐增多.虽然现在看起来,文档里的内容非常简单,但是看着这些内容,好像还依稀记得这一行行代码当时被记录的情景.所以我想把这段回忆保存起来,为刚接触前端的童鞋们提供一个简单的查询的途径,也以此来缅怀我的前端学习之路. ** 此文

jQuery常用数据处理方法小结

 这篇文章主要介绍了jQuery常用数据处理方法,实例总结了trim.param.isArray.isFunction.each等jQuery常用的数据处理方法,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例总结了jQuery常用数据处理方法.分享给大家供大家参考.具体如下: $.trim():删除字符串前后的空白字符. ? 1 2 var str = ' 薯条 '; var formatStr = $.trim(str); //'薯条' $.param():数组或者对象序列化.

最常用的四种大数据分析方法

本文主要讲述数据挖掘分析领域中,最常用的四种数据分析方法:描述型分析.诊断型分析.预测型分析和指令型分析. 当刚涉足数据挖掘分析领域的分析师被问及,数据挖掘分析人员最重要的能力是什么时,他们给出了五花八门的答案. 其实我想告诉他们的是,数据挖掘分析领域最重要的能力是:能够将数据转化为非专业人士也能够清楚理解的有意义的见解. 使用一些工具来帮助大家更好的理解数据分析在挖掘数据价值方面的重要性,是十分有必要的.其中的一个工具,叫做四维分析法. 简单地来说,分析可被划分为4种关键方法. 下面会详细介绍