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

 更新时间:2009年11月12日 22:28:10   作者:  
以下是用jquery控制ASP.NET中的两个asp:listbox控件中选择项的移动。
首先是html代码,页面上放2个listbox控件和2个按钮用于移动项目
复制代码 代码如下:

<table border="0">
<tr>
<td width="156">全部水果:</td>
<td width="142">&nbsp;</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="&gt;&gt;&gt;" onclick="move('listall','listmy');"/><br /><br />
<input type="button" id="btnrighttmove" value="&lt;&lt;&lt;" 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控制两个列表项的值移动。

相关文章

  • jquery中对表单的基本操作代码

    jquery中对表单的基本操作代码

    jquery对表单的基本操作,里面对于checkbox等表单的获取,都有很详细的说明。
    2010-07-07
  • 点击弹出层外区域关闭弹出层jquery特效示例

    点击弹出层外区域关闭弹出层jquery特效示例

    击弹出层 ,点击弹出层外区域关闭弹出层,点击关闭关闭弹出层jquery特效,具体代码如下,喜欢的朋友可以学习下
    2013-08-08
  • jquery点击获取动态数据进行传参问题

    jquery点击获取动态数据进行传参问题

    这篇文章主要介绍了jquery点击获取动态数据进行传参问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • jQuery使用$.ajax提交表单完整实例

    jQuery使用$.ajax提交表单完整实例

    这篇文章主要介绍了jQuery使用$.ajax提交表单的方法,以完整实例形式分析了jQuery基于ajax数据提交的具体步骤与数据处理技巧,非常简单实用,代码备有详尽的注释便于理解,需要的朋友可以参考下
    2015-12-12
  • 详解jQuery中的DOM操作

    详解jQuery中的DOM操作

    本文主要对jQuery中的DOM操作进行了详细全面的介绍。文中举了简单例子,便于理解与学习,对初学者具有很好的参考价值,需要的朋友一起来看下吧
    2016-12-12
  • jquery tab标签页的制作

    jquery tab标签页的制作

    制作标签页(通常说成滑动门)的实现思路是当鼠标在标签上时下面div会显示和标签相对应的内容,随着标签的改变,下面的div也会对应改变内容
    2010-05-05
  • 用JQuery实现表格隔行变色和突出显示当前行的代码

    用JQuery实现表格隔行变色和突出显示当前行的代码

    用JQuery实现表格隔行变色和突出显示当前行的代码,需要的朋友可以参考下
    2012-02-02
  • jQuery实现鼠标拖动div改变位置、大小的实践

    jQuery实现鼠标拖动div改变位置、大小的实践

    这篇文章主要介绍了jQuery实现鼠标拖动div改变位置、大小的实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • jquery插件实现轮播图效果

    jquery插件实现轮播图效果

    这篇文章主要为大家详细介绍了jquery插件实现轮播图效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • jquery 利用show和hidden实现级联菜单示例代码

    jquery 利用show和hidden实现级联菜单示例代码

    级联菜单的实现方法有很多,在本文为大家介绍下使用show和hidden轻松实现下级联效果,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08

最新评论