实际的项目网站中或多或少的或用到多选框,我选用的一款是 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 常用组件实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# bootstrap
# multiselect
# 常用组件
# bootstrap multiselect下拉列表功能
# 基于BootStrap multiselect.js实现的下拉框联动效果
# Bootstrap Multiselect 常用组件实现代码
# bootstrap multiselect 多选功能实现方法
# Bootstrap 下拉多选框插件Bootstrap Multiselect
# JS组件中bootstrap multiselect两大组件较量
# 多选
# 种方法
# 转换为
# 小编
# 单选框
# 选项卡
# 各种各样
# 的是
# 都是
# 是一个
# 如果你
# 文档
# 子句
# 你可以
# 在此
# 不需要
# 说了
# 就好
# 不多
# 较高
相关文章:
如何快速搭建高效香港服务器网站?
如何在服务器上配置二级域名建站?
如何通过免费商城建站系统源码自定义网站主题与功能?
广州商城建站系统开发成本与周期如何控制?
如何在阿里云香港服务器快速搭建网站?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
如何快速生成ASP一键建站模板并优化安全性?
高端建站三要素:定制模板、企业官网与响应式设计优化
油猴 教程,油猴搜脚本为什么会网页无法显示?
建站之家VIP精选网站模板与SEO优化教程整合指南
微信小程序 五星评分(包括半颗星评分)实例代码
建站之星后台密码遗忘?如何快速找回?
大连 网站制作,大连天途有线官网?
再谈Python中的字符串与字符编码(推荐)
怎么将XML数据可视化 D3.js加载XML
建站主机服务器选型指南与性能优化方案解析
如何通过wdcp面板快速创建网站?
建站之星代理如何优化在线客服效率?
制作网站的软件免费下载,免费制作app哪个平台好?
定制建站是什么?如何实现个性化需求?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
如何实现建站之星域名转发设置?
c# await 一个已经完成的Task会发生什么
如何设置并定期更换建站之星安全管理员密码?
深圳网站制作案例,网页的相关名词有哪些?
定制建站流程解析:需求评估与SEO优化功能开发指南
小型网站制作HTML,*游戏网站怎么搭建?
,石家庄四十八中学官网?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
建站之星官网登录失败?如何快速解决?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
威客平台建站流程解析:高效搭建教程与设计优化方案
如何规划企业建站流程的关键步骤?
建站ABC备案流程中有哪些关键注意事项?
,sp开头的版面叫什么?
如何选择高效可靠的多用户建站源码资源?
建站之星如何快速更换网站模板?
建站中国官网:模板定制+SEO优化+建站流程一站式指南
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
,怎么用自己头像做动态表情包?
网站制作公司,橙子建站是合法的吗?
如何确保西部建站助手FTP传输的安全性?
移民网站制作流程,怎么看加拿大移民官网?
php json中文编码为null的解决办法
网站专业制作公司有哪些,做一个公司网站要多少钱?
*请认真填写需求信息,我们会在24小时内与您取得联系。