JavaScript如何實現(xiàn)組合列表框中元素移動效果
首先給大家說下組合框和列表框的區(qū)別:
組合框包括列表框和文本框的功能
文本框:只能輸入數(shù)據(jù)
列表框:只能選擇數(shù)據(jù)
組合框:既能輸入數(shù)據(jù),又能選擇``
應用背景:在頁面中有兩個列表框,需要把其中一個列表框的元素移動到另一個列表框 。
實現(xiàn)的基本思想:
?。?)編寫init方法對兩個列表框進行初始化;
?。?)為body添加onload事件調(diào)用init方法;
?。?)編寫move(s1,s2)把s1中選中的選項移到s2;
?。?)編寫moveAll(s1,s2)把s1中所有的選項都移到s2.
?。?)為按鈕添加onclick事件。
javascript代碼如下:
<script type="text/javascript" language="javascript">
//對下拉框信息進行初始化
function init() {
for (i = ; i < ; i++) {
var y = document.createElement("option");//增加一個元素option
y.text = '選項' + i;
var x=document.getElementById("s");//根據(jù)ID找到列表框
x.add(y, null); //
}
}
//把選中的選項移到另一邊
function move(s, s) {
var index = s.selectedIndex;
if (index == -) {
alert("沒有選中值");
return;
}
s.length++;
s.options[s.length - ].value = s.options[index].value;
s.options[s.length - ].text = s.options[index].text;//s中當前選中的值賦給s的最后一個元素
s.remove(index);//從s中移除當前元素
}
//把一邊的完全移到另一邊
function moveAll(s, s) {
if (s.length == ) {
alert("沒有可用選擇");
return;
}
s.length = s.length + s.length;
for (var i = ; i < s.length; i++) {
s.options[s.length - s.length + i].value = s.options[i].value;
s.options[s.length - s.length + i].text = s.options[i].text;
}
s.length = ;
}
</script>
<body>代碼:
<body onload="init()"> <table> <tr> <td><select id="s" size= style="width:"></select></td> <td><input type="button" name="moveToRight" value=">" onClick="move(s,s)"> <br> <br> <input type="button" name="moveAllToRight" value=">>" onClick="moveAll(s,s)"> <br> <input type="button" name="moveToLeft" value="<" onClick="move(s,s)"> <br> <br> <input type="button" name="moveAllToLeft" value="<<" onClick="moveAll(s,s)"></td> <td><select id="s" name="s" size= style="width:"></select></td> </tr> </table> </body>
以上內(nèi)容給大家介紹了JavaScript如何實現(xiàn)組合列表框中元素移動效果的相關(guān)知識,希望對大家有所幫助!
相關(guān)文章
JS實現(xiàn)數(shù)據(jù)動態(tài)渲染的豎向步驟條
這篇文章主要為大家詳細介紹了JS實現(xiàn)數(shù)據(jù)動態(tài)渲染的豎向步驟條,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-06-06
推薦js實現(xiàn)商品分類到搜索欄友好提示(人機交互)
推薦js實現(xiàn)商品分類到搜索欄友好提示(人機交互)...2007-05-05
在JavaScript里嵌入大量字符串常量的實現(xiàn)方法
在JavaScript文件里嵌入大量字符串常量是經(jīng)常遇到的事。有時為了省事,就把一些界面的HTML和CSS直接寫在JS文件里2013-07-07

