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

2016-02-19 14:38 34 1 收藏

下面是个简单易学的jquery控制listbox中项的移动并排序教程,图老师小编详细图解介绍包你轻松学会,喜欢的朋友赶紧get起来吧!

【 tulaoshi.com - Web开发 】

首先是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(size0&&selsize0)
{
$.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(size0)
{
var text=$(one).text();
var tag=parseInt($(one).attr("tag"));
//循环列表中第一项值下所有元素
$.each($(one).nextAll(), function(id,own){
var nextag=parseInt($(own).attr("tag"));
if(tagnextag)
{
$(one).remove();
$(own).after("option tag=""+tag+"""+text+"/option");
one=$(own).next();
}
});
}
}

这样就完成了简单的js控制两个列表项的值移动。

来源:http://www.tulaoshi.com/n/20160219/1607388.html

延伸阅读
标签: Web开发
终极目的:想做一个方便的排序功能。 具体实现:点击后可以输入排序的数字编号,移开后自动更新数据库。 1,我想把这个功能用span来完成,也就需要一个在页面上监控指定的span的东西,他就是: ready(fn)当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。 $(document).ready(function(){ // 在这里写你的代码... }); 2,页面上span...
本文主要讲解利用android中Matrix控制图形的旋转缩放移动,具体参见一下代码: 代码如下: /**  * 使用矩阵控制图片移动、缩放、旋转  */  public class CommonImgEffectView extends View {      private Context context ;      private Bitmap mainBmp , controlBmp ;  ...
标签: Web开发
每次请求备份管理页面时,服务端会把所以的备份还原信息都传到客户端,然后ui.tabs将两种信息折叠起来分别显示,好在ui.tabs给我提供ajax功能,我们的每个tab可以直接应用另外一个页面 如: 代码如下: div id="container" ul lia href="#fragment-1"span备份/span/a/li lia href="Restore.aspx"span还原/span/a/li /ul /div 但...
标签: Web开发
1 查找元素节点 var $x = $("selector").text() 2 查找属性节点 var $x = $("selector").attr("property") 3 创建节点 var $x = $("html") 4 插入节点 $("selector").append() 向每个匹配的元素内部追加内容 $("selector").appendTo() 等价于.append()操作符左右互换 $("selector").prepend() 向每个匹配的元素内部前置内...
标签: Web开发
默认情况下,在表单(form)的输入框(input)里按回车将会提交(submit)表单。这会造成一个问题:当用户在填写表单时不小心按了回车键(特别是输入框含有历史记录时,这种情况经常发生),这时不完整的表单会被提交。我们可以通过Javascript来屏蔽回车键,这样当用户键入回车键,表单就不会被提交,而且我们还可以根据需要执行别的任务,例如把光...

经验教程

650

收藏

58
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部