jquery控制listbox中项的移动并排序


Posted in Javascript onNovember 12, 2009

首先是html代码,页面上放2个listbox控件和2个按钮用于移动项目

<table border="0"> 
<tr> 
<td width="156">全部水果:</td> 
<td width="142"> </td> 
<td width="482">我挑选的:</td> 
</tr> 
<tr> 
<td rowspan="2"><asp:ListBox SelectionMode="Multiple" ID="listall" Rows="12" Width="156" runat="server"></asp:ListBox></td> 
<td height="41" align="center"> 
<input type="button" id="btnleftmove" value=">>>" onclick="move('listall','listmy');"/><br /><br /> 
<input type="button" id="btnrighttmove" value="<<<" onclick="move('listmy','listall');"/> 
</td> 
<td rowspan="2"><asp:ListBox SelectionMode="Multiple" ID="listmy" Rows="12" Width="156" runat="server"></asp:ListBox></td> 
</tr> 
</table>

下面是在.cs文件中绑定一些数据
public partial class _Default : System.Web.UI.Page 
{ 
protected void Page_Load(object sender, EventArgs e) 
{ 
if (!IsPostBack) 
{ 
BindData(); 
} 
} private void BindData() 
{ 
ArrayList list=DataArray(); 
for (int i = 0; i < list.Count; i++) 
{ 
listall.Items.Add(list[i].ToString()); 
listall.Items[i].Attributes["tag"] = i.ToString(); //用tag记录排序字段 
} 
} 
private ArrayList DataArray() 
{ 
//用到的一些数据,这里已默认按第一个字的拼音排序 
ArrayList list = new ArrayList(); 
list.Add("草莓"); 
list.Add("梨"); 
list.Add("桔子"); 
list.Add("芒果"); 
list.Add("苹果"); 
list.Add("香蕉"); 
return list; 
} 
}

在实际使用时可根据数据库中的字段排序

下面是jquery的代码:

//移动用户选择的角色 
//setname:要移出数据的列表名称 getname:要移入数据的列表名称 
function move(setname,getname) 
{ 
var size=$("#"+setname+" option").size(); 
var selsize=$("#"+setname+" option:selected").size(); 
if(size>0&&selsize>0) 
{ 
$.each($("#"+setname+" option:selected"), function(id,own){ 
var text=$(own).text(); 
var tag=$(own).attr("tag"); 
$("#"+getname).prepend("<option tag=\""+tag+"\">"+text+"</option>"); 
$(own).remove(); 
$("#"+setname+"").children("option:first").attr("selected",true); 
}); 
} 
//重新排序 
$.each($("#"+getname+" option"), function(id,own){ 
orderrole(getname); 
}); 
} //按首字母排序角色列表 
function orderrole(listname) 
{ 
var size=$("#"+listname+" option").size(); 
var one=$("#"+listname+" option:first-child"); 
if(size>0) 
{ 
var text=$(one).text(); 
var tag=parseInt($(one).attr("tag")); 
//循环列表中第一项值下所有元素 
$.each($(one).nextAll(), function(id,own){ 
var nextag=parseInt($(own).attr("tag")); 
if(tag>nextag) 
{ 
$(one).remove(); 
$(own).after("<option tag=\""+tag+"\">"+text+"</option>"); 
one=$(own).next(); 
} 
}); 
} 
}

这样就完成了简单的js控制两个列表项的值移动。
Javascript 相关文章推荐
表单JS弹出填写提示效果代码
Apr 16 Javascript
jQuery实现的一个自定义Placeholder属性插件
Aug 11 Javascript
Node.js入门教程:在windows和Linux上安装配置Node.js图文教程
Aug 14 Javascript
javascript与css3动画结合使用小结
Mar 11 Javascript
js获得当前系统日期时间的方法
May 06 Javascript
Node.js的特点详解
Feb 03 Javascript
jQuery Mobile漏洞会有跨站脚本攻击风险
Feb 12 Javascript
AngularJS实现的简单拖拽功能示例
Jan 02 Javascript
vue.js内置组件之keep-alive组件使用
Jul 10 Javascript
彻底弄懂 JavaScript 执行机制
Oct 23 Javascript
vue项目每30秒刷新1次接口的实现方法
Dec 04 Javascript
详解利用eventemitter2实现Vue组件通信
Nov 04 Javascript
Jquery 获取表单text,areatext,radio,checkbox,select值的代码
Nov 12 #Javascript
两个select之间option的互相添加操作(jquery实现)
Nov 12 #Javascript
XHTML下,JS浮动代码失效的问题
Nov 12 #Javascript
把html页面的部分内容保存成新的html文件的jquery代码
Nov 12 #Javascript
Javascript 定时器调用传递参数的方法
Nov 12 #Javascript
Ext.FormPanel 提交和 Ext.Ajax.request 异步提交函数的区别
Nov 12 #Javascript
JS解析XML的实现代码
Nov 12 #Javascript
You might like
暴雪前总裁遗憾:没尽早追赶Dota 取消星际争霸幽灵
2020/03/08 星际争霸
PHP.MVC的模板标签系统(二)
2006/09/05 PHP
PHP无限分类代码,支持数组格式化、直接输出菜单两种方式
2011/05/18 PHP
Zend的Registry机制的使用说明
2013/05/02 PHP
给WordPress的编辑后台添加提示框的代码实例分享
2015/12/25 PHP
100多行PHP代码实现socks5代理服务器[2]
2016/05/05 PHP
magento后台无法登录解决办法的两种方法
2016/12/09 PHP
thinkphp5实现微信扫码支付
2019/12/23 PHP
Nigma vs AM BO3 第一场2.13
2021/03/10 DOTA
jQuery 开天辟地入门篇一
2009/12/09 Javascript
javascript陷阱 一不小心你就中招了(字符运算)
2013/11/10 Javascript
图片上传插件jquery.uploadify详解
2013/11/15 Javascript
Ext修改GridPanel数据和字体颜色、css属性等
2014/06/13 Javascript
javascript中JSON对象与JSON字符串相互转换实例
2015/07/11 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(二)
2016/05/17 Javascript
AngularJS 执行流程详细介绍
2016/08/18 Javascript
Jquery通过ajax请求NodeJS返回json数据实例
2016/11/08 NodeJs
用原生js做单页应用
2017/01/17 Javascript
Javascript 两种刷新方法以及区别和适用范围
2017/01/17 Javascript
使用canvas及js简单生成验证码方法
2017/04/02 Javascript
AngularJS 中ui-view传参的实例详解
2017/08/25 Javascript
微信小程序 数据绑定及运算的简单实例
2017/09/20 Javascript
vue中axios实现数据交互与跨域问题
2019/05/12 Javascript
JavaScript数组常用的增删改查与其他属性详解
2020/10/13 Javascript
CentOS 6.X系统下升级Python2.6到Python2.7 的方法
2016/10/12 Python
使用python编写简单的小程序编译成exe跑在win10上
2018/01/15 Python
Numpy array数据的增、删、改、查实例
2018/06/04 Python
python使用PIL给图片添加文字生成海报示例
2018/08/17 Python
CSS3实现瀑布流布局与无限加载图片相册的实例代码
2016/12/22 HTML / CSS
HTML5教程之html 5 本地数据库(Web Sql Database)
2014/04/03 HTML / CSS
The Beach People美国:澳洲海滨奢华品牌
2018/07/05 全球购物
法国在线药房:DoctiPharma
2020/10/21 全球购物
应届生财务会计求职信
2013/11/05 职场文书
英语专业毕业生自我鉴定
2013/11/09 职场文书
秋收起义观后感
2015/06/11 职场文书
《烈火英雄》观后感:致敬和平时代的英雄
2019/11/11 职场文书