Jquery+Eayui实现列表选择功能
在做一个列表选择的功能,要实现一个Jquery列表选择器的效果,如图就是很常见的一种列表选择器

不过网上开源的可能要积分,资料没找到合适的,所以自己就简单写了一下,其实实现也不是很难。实现思路:左边双击之后获取元素,在右边附加上就好,右边选择列表双击之后就移除元素
实现效果:

因为系统功能是easyui做的,页面左边是一个table,也是easyui的datagrid,所以就可以调对应方法获取双击某行的元素
创建前端页面:
<rapid:override name="content">
<div region="west" split="true" title="待选列表" style="width:400px;" >
<div class="site-search" >
<div id="search">
<input type="text" name="s" class="text" id="areaName" placeholder="输入地区名称搜索" />
<button type="button" onclick="javascript:queryOption.doQuery(1);" class="submit">搜索</button>
</div>
</div>
<input type="hidden" value="${tipsSeq}" id="tipsSeq"/>
<table id="areaList"></table>
</div>
<div region="center" title="已选列表" style="border:0;">
<table id="selectedList" style="width:100%;"></table>
</div>
<div region="south" >
<div align="right" style="height:31px;">
<input type="button" onclick="javascript:treeOption.closeDialog();" value="取消" />
<input type="button" onclick="javascript:treeOption.batchBind();" value="下一步" />
</div>
</div>
</div>
</rapid:override>
给右边的列表加上选择后就改变颜色为蓝色的css代码:
#selectedList tr:hover{
background-color: #99ccff; color: #252525; cursor: pointer;
}
#selectedList tr:selected{
background-color: #0095E8; color: #fff;
}
主要函数是调用easyui的双击事件,然后将获取到的数据放在addNodeToList函数里再调用,下面给出easyui的所有代码和自己写的addNodeToList函数
onDblClickRow :function(rowIndex,rowData){
var selections = $("#areaList").datagrid('getSelections');
var areaSeq = selections[0].areaSeq;
var areaName = selections[0].areaName;
var status = selections[0].tipsAreaRelaStatus;
if(status =='1'){
$.messager.alert("操作提示","已配置过该提示语,继续配置数据将覆盖旧数据!","warning");
return;
}
//添加节点
addNodeToList(1,areaSeq,areaName,status);
}
$('#areaList').treegrid({
fit: true,
nowrap: true,
autoRowHeight: true,
animate:true,
scrollbarSize: 0,
striped: true,
collapsible:true,
singleSelect:true,
rownumbers:true,
url:'/loadTipsAreaRelatedData.do?tipsSeq='+$("#tipsSeq").val(),
idField:'areaSeq',
treeField:'areaName',
columns:[[
{field:'ck', checkbox: true, hidden:true},
{field:'areaSeq', hidden:true},
{field:'areaName',title:'地区名称',width:'60%'},
{field:'tipsAreaRelaStatus',title:'状态',width:'40%',
formatter: function (val, rowdata, index) {
if(val =='1'){
return '<span style="color:#00B2EE;">已配置</span>';
}else{
return '<span>未配置</span>';
}
}
}
]],
onBeforeLoad:function(row,param){//加载之前
if(row){
$(this).treegrid('options').url = '/loadSubTipsAreaRelatedData.do?tipsSeq='+$("#tipsSeq").val()+'&parentAreaSeq=' + row.areaSeq;
}else{
$(this).treegrid('options').url = '/loadTipsAreaRelatedData.do?tipsSeq='+$("#tipsSeq").val();
}
},
onDblClickRow :function(rowIndex,rowData){
var selections = $("#areaList").datagrid('getSelections');
var areaSeq = selections[0].areaSeq;
var areaName = selections[0].areaName;
var status = selections[0].tipsAreaRelaStatus;
if(status =='1'){
$.messager.alert("操作提示","已配置过该提示语,继续配置数据将覆盖旧数据!","warning");
return;
}
//添加节点
treeOption.addNodeToList(1,areaSeq,areaName,status);
}
});
function addNodeToList(n,areaSeq,areaName,status){
var tableStr = $("#selectedList");
var trStr = "<tr id="+areaSeq
+" class='datagrid-row' ondblclick='javascript:removeNodeToList("+areaSeq+");''>"
+"<td>"+areaName+"</td></tr>";
var tr = $("#selectedList").find("tr");
var trNum = tr.length;
if(trNum == 0){
tableStr.append(trStr);
}else{
var count = 0;
//思路是:遍历表格,如果有元素就再添加,没有那个元素就添加
$("#selectedList tr").each(function(){
var id =$(this).attr("id");
if(areaSeq == id){
count++;
}
});
if(count==0){
tableStr.append(trStr);
}
}
}
右边列表双击可以移除元素:
function removeNodeToList(areaSeq){
$("#selectedList").find("#"+areaSeq).remove();
}
思路:左边双击之后获取元素,在右边附加上就好,右边选择列表双击之后就移除元素
Jquery+Eayui实现列表选择功能的更多相关文章
- 多行滚动jQuery循环新闻列表代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javascript和jquery中获取列表的索引
网页中的图片预览一般都需要获取图片列表的索引,或则图片对应的标签的索引,以此达到点击相应的标签获取索引,显示相应的图片 列表有很多种表达的方式,一种是 <ul> <li>苹果& ...
- jquery.dragsort实现列表拖曳、排序
在一次工作中需要将功能模块实现拖曳并且排序,并且将排序结果保存到数据库,用户下次登录后直接读取数据库排序信息进行显示.LZ找了好多插件,最后发现 jquery.dragsort 这款插件是最好使用的, ...
- jquery动态添加列表后样式失效解决方式
最近在做一个通讯录,使用jquery mobile方式来做,在动态添加列表后,listview原有的样式失效,折腾一会,找出解决办法.代码如下. <%@ page language=" ...
- jquery mobile listview列表属性(搜索自动填充检索效果)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- JQuery加载列表实现动画滚动(自上而下挤)
这个例子是jquery动态加载列表,并通过定时刷新,实现其循环滚动效果的一个例子. 1.HTML代码: <div class="fake-table"> <li ...
- multiselect2side:jQuery多选列表框插件
http://blog.csdn.net/rosanu_blog/article/details/8550723 http://www.bkjia.com/jQuery/449193.html < ...
- jQuery取得循环列表的第一列值
有例如以下的表格: <table class="list_tab" id="personalDetail"> <tr class=" ...
- jQuery入门——实现列表的显示隐藏与实现轮播图
列表的显示与隐藏 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head& ...
随机推荐
- 《笨方法学Python》加分题33
while-leep 和我们接触过的 for-loop 类似,它们都会判断一个布尔表达式的真伪.也和 for 循环一样我们需要注意缩进,后续的练习会偏重这方面的练习.不同点在于 while 循环在执行 ...
- springBoot 使用拦截器 入坑
近期使用SpringBoot 其中用到了拦截器 结果我的静态资源被全部拦截了,让我导致了好久才搞好: 看下图项目结构: 问题描述:上图划红框的资源都被拦截器给拦截了,搞得项目中不能访问:解决问题就是在 ...
- JavaScript深拷贝
1,JSON.parse(JSON.stringify(obj)) 使用JSON实现深拷贝必须要求对象是符合JSON安全的,不了解JSON安全的自行百度. 2,lodash/underscore _ ...
- Spring Boot的Maven配置
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...
- Windows下 tensorboard出现ValueError:Invalid format string
Windows下 tensorboard出现ValueError:Invalid format string错误时,是格式错误问题,解决方法参阅我的另一篇博客 https://www.jianshu. ...
- php hash_file
string hash_file ( string $algo , string $filename [, bool $raw_output = FALSE ] ) 参数¶ algo 要使用的哈希算法 ...
- gulp使用详解
前面整理了 gulp使用入门,本节介绍相关的压缩 1.压缩js文件 步骤同基础步骤,相关可以看入门篇 npm install gulp-uglify --save-dev 引入js压缩库 gulpfi ...
- tab选项卡--jq
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- MySQL数据库(三)索引总结
一.什么是索引? 索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存. 如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录 ...
- Windows批处理命令学习中遇到的坑--持续更新中
再次拾起windows批处理命令,下边将一些遇到的小问题写出来,希望可以帮到大家 1.set命令:set主要的作用是为变量赋值,类似于编程语言中的var i = Value:但是在使用的过程中一定要注 ...