jquery控制listbox中项的移动并排序的实现代码
2023-06-13 09:14:24 时间
首先是html代码,页面上放2个listbox控件和2个按钮用于移动项目
复制代码代码如下:
<tableborder="0">
<tr>
<tdwidth="156">全部水果:</td>
<tdwidth="142"></td>
<tdwidth="482">我挑选的:</td>
</tr>
<tr>
<tdrowspan="2"><asp:ListBoxSelectionMode="Multiple"ID="listall"Rows="12"Width="156"runat="server"></asp:ListBox></td>
<tdheight="41"align="center">
<inputtype="button"id="btnleftmove"value=">>>"onclick="move("listall","listmy");"/><br/><br/>
<inputtype="button"id="btnrighttmove"value="<<<"onclick="move("listmy","listall");"/>
</td>
<tdrowspan="2"><asp:ListBoxSelectionMode="Multiple"ID="listmy"Rows="12"Width="156"runat="server"></asp:ListBox></td>
</tr>
</table>
下面是在.cs文件中绑定一些数据
publicpartialclass_Default:System.Web.UI.Page
{
protectedvoidPage_Load(objectsender,EventArgse)
{
if(!IsPostBack)
{
BindData();
}
}
privatevoidBindData()
{
ArrayListlist=DataArray();
for(inti=0;i<list.Count;i++)
{
listall.Items.Add(list[i].ToString());
listall.Items[i].Attributes["tag"]=i.ToString();//用tag记录排序字段
}
}
privateArrayListDataArray()
{
//用到的一些数据,这里已默认按第一个字的拼音排序
ArrayListlist=newArrayList();
list.Add("草莓");
list.Add("梨");
list.Add("桔子");
list.Add("芒果");
list.Add("苹果");
list.Add("香蕉");
returnlist;
}
}
在实际使用时可根据数据库中的字段排序
下面是jquery的代码:
//移动用户选择的角色
//setname:要移出数据的列表名称getname:要移入数据的列表名称
functionmove(setname,getname)
{
varsize=$("#"+setname+"option").size();
varselsize=$("#"+setname+"option:selected").size();
if(size>0&&selsize>0)
{
$.each($("#"+setname+"option:selected"),function(id,own){
vartext=$(own).text();
vartag=$(own).attr("tag");
$("#"+getname).prepend("<optiontag=\""+tag+"\">"+text+"</option>");
$(own).remove();
$("#"+setname+"").children("option:first").attr("selected",true);
});
}
//重新排序
$.each($("#"+getname+"option"),function(id,own){
orderrole(getname);
});
}
//按首字母排序角色列表
functionorderrole(listname)
{
varsize=$("#"+listname+"option").size();
varone=$("#"+listname+"option:first-child");
if(size>0)
{
vartext=$(one).text();
vartag=parseInt($(one).attr("tag"));
//循环列表中第一项值下所有元素
$.each($(one).nextAll(),function(id,own){
varnextag=parseInt($(own).attr("tag"));
if(tag>nextag)
{
$(one).remove();
$(own).after("<optiontag=\""+tag+"\">"+text+"</option>");
one=$(own).next();
}
});
}
}
相关文章
- 生成二维码的 jQuery 插件:jquery.qrcode.js
- jQuery Google Charts—-一个封装google chart api的jquery插件详解编程语言
- jQuery图片切换插件jquery.cycle.js详解编程语言
- jquery控制元素的隐藏和显示的几种方法。详解编程语言
- jQuery延迟加载(懒加载)插件 – jquery.lazyload.js详解编程语言
- jQuery内容伪类选择
- jquery控制listbox中项的移动并排序
- JQuery将元素显示在屏幕的中央的代码
- 25个非常棒的jQuery滑块插件和教程小结
- jQuery控制图片的hover效果(smartRollover.js)
- jQuery学习笔记(2)--用jquery实现各种模态提示框代码及项目构架
- 使用jQuery同时控制四张图片的伸缩实现代码
- 基于jquery实现控制经纬度显示地图与卫星
- jquery批量控制form禁用的代码
- js加入收藏以及使用Jquery更改透明度
- 使用jquery修改表单的提交地址基本思路
- 浅谈JSON和JSONP区别及jQuery的ajaxjsonp的使用
- jQuery控制的不同方向的滑动(向左、向右滑动等)
- 使用jquery+CSS实现控制打印样式
- JQuery控制div外点击隐藏而div内点击不会隐藏的方法
- jquery使用正则表达式验证email地址的方法
- Jquery设置attr的disabled属性控制某行显示或者隐藏