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& ...
随机推荐
- 移动端h5调试方法
charles代理 使用技巧如下: http://www.jianshu.com/p/fdd7c681929c 1.手机wifi连接代理 以iphone为例,长按住wifi, 进入下一页,可看到 HT ...
- python基础中的四大天王-增-删-改-查
列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...
- 如何配置nginx屏蔽恶意域名解析指向《包含隐藏nginx版本号》
恶意域名指向: 比如,有一个垃圾域名将解析指向到了你们服务器的IP,一般多一个解析可能不会有什么问题,但是现在全民备案时期,可能你的运营商会联系你,说你们的域名没备案,可能会封你们的80端口,然后会导 ...
- Jython 安装使用
Jython 官网:https://jython.org/ 下载 下载页面:https://jython.org/downloads.html jython-installer-${version}. ...
- Job集群设计
- LINUX日常操作二
参见:Linux日常操作一 selinux 开启和关闭 一.查看SELinux状态:1./usr/sbin/sestatus -v ##如果SELinux status参数为enabled ...
- Ajax使用的五步法
Ajax使用的五步法 <script type="text/javascript"> //用于保存XMLHttpRequest对象的变量,由于整个过 ...
- AspNetCore OpenId
1 Server端 public class Startup { public Startup(IConfiguration configuration) { Configuration = conf ...
- Java在ServletContextListener、过滤器、拦截器解决对象无法注入问题
1.通用方法: // 数据库日志操作对象 private LogInfoServiceIFC logInfoServiceProxy; @Override public void contextIni ...
- qq通讯录