在做一个列表选择的功能,要实现一个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实现列表选择功能的更多相关文章

  1. 多行滚动jQuery循环新闻列表代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. javascript和jquery中获取列表的索引

    网页中的图片预览一般都需要获取图片列表的索引,或则图片对应的标签的索引,以此达到点击相应的标签获取索引,显示相应的图片 列表有很多种表达的方式,一种是 <ul> <li>苹果& ...

  3. jquery.dragsort实现列表拖曳、排序

    在一次工作中需要将功能模块实现拖曳并且排序,并且将排序结果保存到数据库,用户下次登录后直接读取数据库排序信息进行显示.LZ找了好多插件,最后发现 jquery.dragsort 这款插件是最好使用的, ...

  4. jquery动态添加列表后样式失效解决方式

    最近在做一个通讯录,使用jquery mobile方式来做,在动态添加列表后,listview原有的样式失效,折腾一会,找出解决办法.代码如下. <%@ page language=" ...

  5. jquery mobile listview列表属性(搜索自动填充检索效果)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  6. JQuery加载列表实现动画滚动(自上而下挤)

    这个例子是jquery动态加载列表,并通过定时刷新,实现其循环滚动效果的一个例子. 1.HTML代码: <div class="fake-table"> <li ...

  7. multiselect2side:jQuery多选列表框插件

    http://blog.csdn.net/rosanu_blog/article/details/8550723 http://www.bkjia.com/jQuery/449193.html < ...

  8. jQuery取得循环列表的第一列值

    有例如以下的表格: <table class="list_tab" id="personalDetail"> <tr class=" ...

  9. jQuery入门——实现列表的显示隐藏与实现轮播图

    列表的显示与隐藏 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head& ...

随机推荐

  1. Ax用Excel导出表的字段属性信息

    static void CKT_ExportTableColnum(Args _args){ LJD_QaHalf_Figure _LJD_QaHalf_Figure; SysDictTable sd ...

  2. jquery倒计时按钮常用于验证码倒计时

    <!doctype html><html><head> <meta charset="utf-8"> <title>jq ...

  3. clientdataset新增append新增多条记录的时候报错 key valation

    在前面加上两句 adsDetail.Active := False; adsDetail.CreateDataSet;

  4. Trachtenberg(特拉亨伯格)速算系统

    二战期间,俄国的数学家Jakow Trachtenberg(1888-1953)被关进纳粹集中营,在狱中,他开发出了一套心算算法,这套算法后来被命名为Trachtenberg(特拉亨伯格)速算系统. ...

  5. left join中where与on的区别

    举例进行说明,我们现在有两个表,即商品表(products)与sales_detail(销售记录表).我们主要是通过这两个表来对MySQL关联left join 条件on与where 条件的不同之处进 ...

  6. mac电脑Git提交代码到Github提示git-credential-osxkeychain 验证解决方案

    ## 啊哈哈 这个简单,直接给出当前mac电脑登录账号密码即可,^_*,拿走不谢!!

  7. VSCode 绿色版(zip压缩包) 添加右键菜单 使用VSCode 打开文件或文件夹

    微软官方下载VSCode 可以下载exe安装外还可以下载zip 压缩包 下载地址: https://code.visualstudio.com/Download 但是zip压缩包却没有了 右键使用VS ...

  8. css关于浮动的高度塌陷

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 微信小程序的一些小知识点

    1. <text>hello</text> 只有包含在<text>标签内的文字,在手机上才可以长按选中. 2. 单位px:自适应rpx = 1:1 物理像素除以2得 ...

  10. [js]jQuery EasyUI的linkbutton组件disable方法无法禁用jQuery绑定事件的问题分析

    问题由来 linkbutton 是 jQuery EasyUI 中常用的一个控件,可以使用它创建按钮.用法很简单,使用 a 标签给一个easyui-linkbutton 的class就可以了. < ...