Bootstrap Multiselect 常用组件实现代码

作者:Orson 时间:2024-05-21 10:14:36 

实际的项目网站中或多或少的或用到多选框,我选用的一款是 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);%>
         <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+=")";
       }

总结

以上所述是小编给大家介绍的Bootstrap Multiselect 常用组件实现代码网站的支持!

来源:http://www.cnblogs.com/java-class/p/4680255.html

标签:bootstrap,multiselect
0
投稿

猜你喜欢

  • Python实现照片卡通化

    2021-03-29 18:45:40
  • Python中的Pandas 时间函数 time 、datetime 模块和时间处理基础讲解

    2022-08-01 05:18:41
  • SQL Server数据库连接查询和子查询实战案例

    2024-01-15 02:44:21
  • python实现俄罗斯方块游戏(改进版)

    2022-03-10 07:55:48
  • 在Python 中将类对象序列化为JSON

    2023-06-11 16:41:32
  • ASP实现上传图片自动压缩图片大小

    2010-01-25 12:47:00
  • Python基于list的append和pop方法实现堆栈与队列功能示例

    2022-10-20 02:26:26
  • 编写和优化SQL Server的存储过程

    2009-04-13 10:13:00
  • asp下用fso和ado.stream写xml文件的方法

    2011-04-07 10:55:00
  • php与javascript正则匹配中文的方法分析

    2024-04-10 14:00:01
  • 浅谈node的事件机制

    2024-05-05 09:22:03
  • PyInstaller运行原理及常用操作详解

    2022-09-15 03:57:26
  • ASP把长的数字用格式化为货币样式的函数

    2009-09-18 14:49:00
  • python jenkins 打包构建代码的示例代码

    2022-10-05 02:22:02
  • Python按行读取文件的简单实现方法

    2023-06-14 22:55:49
  • python工具之清理 Markdown 中没有引用的图片

    2022-02-14 11:44:39
  • 解决mysql5中文乱码问题的方法

    2024-01-15 07:47:52
  • Python实现将Excel转换成为image的方法

    2023-08-10 03:59:55
  • chatgpt国内镜像 pycharm idea插件使用详解

    2022-03-29 10:08:41
  • python调用subprocess模块实现命令行操作控制SVN的方法

    2022-07-18 02:01:03
  • asp之家 网络编程 m.aspxhome.com