ligerUI---ListBox(列表框可移动的实例)


Posted in Javascript onNovember 28, 2017

写在前面:

对于可移动的列表框,ligerui中也对其进行了封装,可以直接照着demo拿来用,不过那都是直接在页面上静态初始化的数据,那么如何从后台获取?

前面有了对ligerui的一些组件的使用经验后,在这里其实 对于从后台获取数据在前台页面进行显示,都大同小异。也不是很难。

即要么是在ligerui组件中直接使用其url属性向后台发送请求,要么是单独发送一个ajax请求拿到数据后,通过获取组件,然后设置其data属性。嘿嘿。。

下面就直接使用url属性来发送请求吧。。。。。

前台页面:

<script type="text/javascript">
 var box1,box2;

 $(function() {

  //初始化8个listbox
  box1 = $("#listbox1").ligerListBox({
   isShowCheckBox: true,
   isMultiSelect: true,
   height: 140,
   //发送给后台的请求
   url: '${baseURL}/getDeviceByAll.action',
  });
  box2 = $("#listbox2").ligerListBox({
   isShowCheckBox: true,
   isMultiSelect: true,
   height: 140,

  });

  var tempData2 = [{id:1,text:"aa"},{id:2,text:"bb"}];

  //button点击事件
  $("#btn1").click(function(){
   setListBoxData(tempData2);
  });

 });



 function setListBoxData(tempData2){
  //貌似只能通过id来移除了 用removeItems不可以达到效果
  //例如移除id为1,2的然后添加到左边
  for(var i=0;i<tempData2.length;i++){
   box1.removeItem(tempData2[i].id);
  }
  box2.addItems(tempData2);
 }

 //===========listbox四个按钮点击相关函数===========
 function moveToLeft1()
 {
  var selecteds = box2.getSelectedItems();
  if (!selecteds || !selecteds.length) return;
  box2.removeItems(selecteds);
  box1.addItems(selecteds);

 }

 function moveToRight1()
 {
  var selecteds = box1.getSelectedItems();
  if (!selecteds || !selecteds.length) return;
  box1.removeItems(selecteds);
  box2.addItems(selecteds);


 }
 function moveAllToLeft1()
 {
  var selecteds = box2.data;
  if (!selecteds || !selecteds.length) return;
  box1.addItems(selecteds);
  box2.removeItems(selecteds);

 }
 function moveAllToRight1()
 {
  var selecteds = box1.data;
  if (!selecteds || !selecteds.length) return;
  box2.addItems(selecteds);
  box1.removeItems(selecteds);

 }




</script>
<style type="text/css">
 .middle input {
  display: block;width:30px; margin:2px;
 }
</style>
</head>
<body>

  <div>
   <div style="float:left;font-size:15px;width:150px;text-align: center">Support Devices:</div>
   <div style="margin:4px;float:left;">
    <div id="listbox1"></div>
   </div>
   <div style="margin:4px;float:left;" class="middle">
    <input type="button" onclick="moveToLeft1()" value="<" />
    <input type="button" onclick="moveToRight1()" value=">" />
    <input type="button" onclick="moveAllToLeft1()" value="<<" />
    <input type="button" onclick="moveAllToRight1()" value=">>" />
   </div>
   <div style="margin:4px;float:left;">
    <div id="listbox2"></div>
   </div>
  </div>

  <input type="button" value="点击" id="btn1">


</body>

后台action:

private JSONArray jsonArray;
 public JSONArray getJsonArray() {
  return jsonArray;
 }
 public String getDeviceByAll() throws Exception{
  List<Device> deviceList = deviceService.getAll(Device.class);

  jsonArray = new JSONArray();
  for(Device device:deviceList){
   JSONObject obj = new JSONObject();
   //listbox对应的数据格式要有text、id字段
   obj.put("id",device.getDevId());
   obj.put("text",device.getDevName());
   jsonArray.add(obj);

  }
  return SUCCESS;
 }

好啦,这样就成功了,当然 我这里是省略了后台如何将json数据传递到前台,因为在我写ligerui的其他组件(ligerGrid,ligerForm)的时候已经写过了,就不再重复说了

效果演示截图:(省略向左向右的移动效果图)

ligerUI---ListBox(列表框可移动的实例)

在不勾选数据的情况下,点击“点击”按钮,的效果图如下:
ligerUI---ListBox(列表框可移动的实例)

其实在移除的过程中,一开始使用的removeItems()方法,但是测试貌似不可以移除,故采用removeItem()的方法,根据id来移除。。

Javascript 相关文章推荐
js下用eval生成JSON对象
Sep 17 Javascript
js 针对html DOM元素操作等经验累积
Mar 11 Javascript
一个jquery实现的不错的多行文字图片滚动效果
Sep 28 Javascript
Javascript 5种方法实现过滤删除前后所有空格
Jun 22 Javascript
BootStrap日期控件在模态框中选择时间下拉菜单无效的原因及解决办法(火狐下不能点击)
Aug 18 Javascript
JavaScript中${pageContext.request.contextPath}取值问题及解决方案
Dec 08 Javascript
js仿网易表单及时验证功能
Mar 07 Javascript
vue.js在标签属性中插入变量参数的方法
Mar 06 Javascript
Vue波纹按钮组件制作
Apr 30 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
Jun 14 Javascript
node全局变量__dirname与__filename的区别
Jan 14 Javascript
微信小程序实现日历小功能
Nov 18 Javascript
基于vue2实现上拉加载功能
Nov 28 #Javascript
微信小程序模板和模块化用法实例分析
Nov 28 #Javascript
基于Vue的移动端图片裁剪组件功能
Nov 28 #Javascript
javaScript canvas实现(画笔大小 颜色 橡皮的实例)
Nov 28 #Javascript
基于Vue框架vux组件库实现上拉刷新功能
Nov 28 #Javascript
JavaScript中关于class的调用方法
Nov 28 #Javascript
基于vue+canvas的excel-like组件实例详解
Nov 28 #Javascript
You might like
Smarty模板学习笔记之Smarty简介
2014/05/20 PHP
PHP实现无限级分类(不使用递归)
2015/10/22 PHP
浅谈PHP eval()函数定义和用法
2016/06/21 PHP
JQuery UI皮肤定制
2009/07/27 Javascript
在IE下获取object(ActiveX)的Param的代码
2009/09/15 Javascript
基于JQuery的asp.net树实现代码
2010/11/30 Javascript
自制的文件上传JS控件可支持IE、chrome、firefox etc
2014/04/18 Javascript
jquery-syntax动态语法着色示例代码
2014/05/14 Javascript
Javascript封装DOMContentLoaded事件实例
2014/06/12 Javascript
jquery地址栏链接与a标签链接匹配之特效代码总结
2015/08/24 Javascript
jQuery入门之层次选择器实例简析
2015/12/11 Javascript
Vue学习笔记进阶篇之单元素过度
2017/07/19 Javascript
Vue实现一个返回顶部backToTop组件
2017/07/25 Javascript
React如何利用相对于根目录进行引用组件详解
2017/10/09 Javascript
使用nodejs+express实现简单的文件上传功能
2017/12/27 NodeJs
js HTML DOM EventListener功能与用法实例分析
2020/04/27 Javascript
小程序选项卡以及swiper套用(跨页面)
2020/06/19 Javascript
JS实现多选框的操作
2020/06/24 Javascript
three.js着色器材质的内置变量示例详解
2020/08/16 Javascript
[36:05]DOTA2亚洲邀请赛 3.31 小组赛 A组 Liquid vs Optic
2018/04/01 DOTA
python实现在每个独立进程中运行一个函数的方法
2015/04/23 Python
详解pyppeteer(python版puppeteer)基本使用
2019/06/12 Python
python 使用tkinter+you-get实现视频下载器
2020/11/17 Python
Python3.8.2安装包及安装教程图文详解(附安装包)
2020/11/28 Python
ECCO俄罗斯官网:北欧丹麦鞋履及皮具品牌
2020/06/26 全球购物
应用化学专业职业生涯规划书
2014/01/22 职场文书
浙大毕业生自荐信
2014/01/26 职场文书
教师廉洁自律个人总结
2015/02/10 职场文书
车间质检员岗位职责
2015/04/08 职场文书
2015年学校后勤工作总结
2015/04/08 职场文书
建国大业电影观后感
2015/06/01 职场文书
仰望星空观后感
2015/06/10 职场文书
大学学生会竞选稿
2015/11/19 职场文书
Pytest中conftest.py的用法
2021/06/27 Python
《总之就是很可爱》新作短篇动画《总之就是很可爱~制服~》将于2022年夏天播出
2022/04/07 日漫
python中 .npy文件的读写操作实例
2022/04/14 Python