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 相关文章推荐
你的编程语言可以这样做吗?
Sep 07 Javascript
jQuery过滤选择器:not()方法使用介绍
Apr 20 Javascript
jquery动态添加删除(tr/td)
Feb 09 Javascript
jQuery Validate表单验证深入学习
Dec 18 Javascript
jquery ui dialog替代confirm实例分析
Jan 25 Javascript
jQuery简单倒计时效果完整示例
Sep 20 Javascript
快速实现jQuery多级菜单效果
Feb 01 Javascript
Bootstrap路径导航与分页学习使用
Feb 08 Javascript
JS switch判断 三目运算 while 及 属性操作代码
Sep 03 Javascript
解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题
Aug 20 Javascript
Vue Cli3 创建项目的方法步骤
Oct 15 Javascript
Vue组件之单向数据流的解决方法
Nov 10 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
laravel中命名路由的使用方法
2017/02/24 PHP
Yii2 中实现单点登录的方法
2018/03/09 PHP
extJs 下拉框联动实现代码
2010/04/09 Javascript
Js+Flash实现访问剪切板操作
2012/11/20 Javascript
JS模块与命名空间的介绍
2013/03/22 Javascript
通过Jquery的Ajax方法读取将table转换为Json
2014/05/31 Javascript
javascript的tab切换原理与效果实现方法
2015/01/10 Javascript
javascript中Function类型详解
2015/04/28 Javascript
jQuery实现淡入淡出的模态框
2017/02/09 Javascript
vue2.0实现倒计时的插件(时间戳 刷新 跳转 都不影响)
2017/03/30 Javascript
基于Vue实现tab栏切换内容不断实时刷新数据功能
2017/04/13 Javascript
vue树形结构获取键值的方法示例
2018/06/21 Javascript
vue打包之后生成一个配置文件修改接口的方法
2018/12/09 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
2020/08/03 Javascript
vscode自定义vue模板的实现
2021/01/27 Vue.js
python文件比较示例分享
2014/01/10 Python
python爬虫的工作原理
2017/03/05 Python
Python中print和return的作用及区别解析
2019/05/05 Python
利用Python进行图像的加法,图像混合(附代码)
2019/07/14 Python
在django中,关于session的通用设置方法
2019/08/06 Python
Django关于admin的使用技巧和知识点
2020/02/10 Python
python框架flask入门之路由及简单实现方法
2020/06/07 Python
Python3爬虫中关于Ajax分析方法的总结
2020/07/10 Python
使用python批量修改XML文件中图像的depth值
2020/07/22 Python
改变 Python 中线程执行顺序的方法
2020/09/24 Python
CSS3实现鼠标悬停显示扩展内容
2016/08/24 HTML / CSS
几个常见的软件测试问题
2016/09/07 面试题
励志演讲稿范文
2014/04/29 职场文书
法制宣传教育方案
2014/05/09 职场文书
学校证明范文
2015/06/24 职场文书
《灰雀》教学反思
2016/02/19 职场文书
如何用JavaScipt测网速
2021/05/09 Javascript
python基础入门之普通操作与函数(三)
2021/06/13 Python
python基础之错误和异常处理
2021/10/24 Python
对讲机知识
2022/04/07 无线电
Win Server2016远程桌面如何允许多用户同时登录
2022/06/10 Servers