实现option上下移动_js 控制select下拉列表框中option选项的上下移动

代码如下:

复制代码 代码示例:

控制select下拉列表框中option选项的上下移动_www.jquerycn.cn

var x=null;

var listObj=null;

//鼠标按下不放时的操作

function setTimeStart(type)

{

listObj=document.getElementById('forder');

//超过0.3秒启动连续的向上(下)的操作

if(type=="up")

{

x=setTimeout(upListItem,300);

}else

{

x=setTimeout(downListItem,300);

}

}

//将选中item向上

function upListItem()

{

var selIndex=listObj.selectedIndex;

if(selIndex<0)

{

if(x!=null){clearTimeout(x);}

alert("请先选中一项!");

return;

}

if(selIndex==0)

{

if(x!=null){clearTimeout(x);}

alert("已经移到第一位!");

return;

}var selValue=listObj.options[selIndex].value;

var selText=listObj.options[selIndex].text;

listObj.options[selIndex].value=listObj.options[selIndex-1].value;

listObj.options[selIndex].text=listObj.options[selIndex-1].text;

listObj.options[selIndex-1].value=selValue;

listObj.options[selIndex-1].text=selText;

listObj.selectedIndex=selIndex-1;

if(selIndex+1>0)

{

x=setTimeout(upListItem,200)

}

}

//将选中item向下

function downListItem()

{

var selIndex=listObj.selectedIndex;

if(selIndex<0)

{

if(x!=null){clearTimeout(x);}

alert("请先选中一项!");

return;

}

if(selIndex==listObj.options.length-1)

{

if(x!=null){clearTimeout(x);}

alert("已经移到最后一位!");

return;

}var selValue=listObj.options[selIndex].value;

var selText=listObj.options[selIndex].text;

listObj.options[selIndex].value=listObj.options[selIndex+1].value;

listObj.options[selIndex].text=listObj.options[selIndex+1].text;

listObj.options[selIndex+1].value=selValue;

listObj.options[selIndex+1].text=selText;

listObj.selectedIndex=selIndex+1;

if(selIndex+1

{

x=setTimeout(downListItem,200)

}

}

οnclick="listObj=document.getElementById('forder');upListItem();clearTimeout(x);" ID="Button1" NAME="Button1">

οnmοuseup="clearTimeout(x);" οnclick="listObj=document.getElementById('forder');downListItem();clearTimeout(x);" ID="Button2" NAME="Button2">

1

2

3

4

5

6

7

8

9

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值