jQuery實現(xiàn)下拉框左右選擇的簡單實例

就是實現(xiàn)這個效果的,選中添加到右邊,全部添加到右邊,選中刪除到左邊,全部刪除到左邊。
html部分:
<body>
<div class="centent">
<select multiple="multiple" id="select1" style="width:100px;height:160px;">
<option value="1">選項1</option>
<option value="2">選項2</option>
<option value="3">選項3</option>
<option value="4">選項4</option>
<option value="5">選項5</option>
<option value="6">選項6</option>
<option value="7">選項7</option>
</select>
<div>
<span id="add" >選中添加到右邊>></span>
<span id="add_all" >全部添加到右邊>></span>
</div>
</div>
<div class="centent">
<select multiple="multiple" id="select2" style="width: 100px;height:160px;">
<option value="8">選項8</option>
</select>
<div>
<span id="remove"><<選中刪除到左邊</span>
<span id="remove_all"><<全部刪除到左邊</span>
</div>
</div>
</body>
這里要注意的是select的multiple屬性,只有添加了之后,才會在select框中出現(xiàn)多個select選項。
否則只會顯示出一條。
jQuery代碼解析:
<script type="text/javascript">
$(function(){
//移到右邊
$('#add').click(function() {
//獲取選中的選項,刪除并追加給對方
$('#select1 option:selected').appendTo('#select2');
});
//移到左邊
$('#remove').click(function() {
$('#select2 option:selected').appendTo('#select1');
});
//全部移到右邊
$('#add_all').click(function() {
//獲取全部的選項,刪除并追加給對方
$('#select1 option').appendTo('#select2');
});
//全部移到左邊
$('#remove_all').click(function() {
$('#select2 option').appendTo('#select1');
});
//雙擊選項
$('#select1').dblclick(function(){ //綁定雙擊事件
//獲取全部的選項,刪除并追加給對方
$("option:selected",this).appendTo('#select2'); //追加給對方
});
//雙擊選項
$('#select2').dblclick(function(){
$("option:selected",this).appendTo('#select1');
});
});
</script>
這里要注意的是$("option:selected",this)。這個看起來有點奇怪。其實$()有2個參數(shù),一個是選擇器,一個是作用域。 要和$("xxxx,xxx")區(qū)分。通常意義下的$('xxxx')其實是默認了第二個作用域。完整說應(yīng)該是$('xxxx',document)。這里加上this之后,作用域就限制在#select1中或#select2中了。也就是select1中的選中項被添加到#select2的后面。
效果類似于$("#select1 option:selected")。
如果不加上,this這個參數(shù)的話,就會牽扯到全局中的選中項。就會出錯。
注意點2:
append()與appendTo()方法的區(qū)別。
append(content|fn)向每個匹配的元素內(nèi)部追加內(nèi)容。
appendTo(content)把所有匹配的元素追加到另一個指定的元素元素集合中。
前者是向匹配的元素中添加內(nèi)容的,后者是把匹配的素有元素追加到另一個指定的元素集合中的。
比如$("p").append("<b>Hello</b>");是向p元素中追加內(nèi)容<b>Hello</b>。
原來的p元素內(nèi)容:<p>I would like to say: </p>現(xiàn)在的p元素內(nèi)容:[ <p>I would like to say: <b>Hello</b></p> ]$("p").appendTo("div");將p元素追加到div元素中。原來的內(nèi)容:<p>I would like to say: </p>
<div></div><div></div>結(jié)果:<div><p>I would like to say: </p></div> <div><p>I would like to say: </p></div>
相關(guān)文章
jquery validation驗證身份證號,護照,電話號碼,email(實例代碼)
jquery validation驗證身份證號,護照,電話號碼,email(實例代碼)。需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11淺談jquery.form.js的ajaxSubmit和ajaxForm的使用
下面小編就為大家?guī)硪黄獪\談jquery.form.js的ajaxSubmit和ajaxForm的使用。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09jquery選擇器、屬性設(shè)置用法經(jīng)驗總結(jié)
最近做項目用到了jquery。在做的過程中走了很多彎路,不停的搜索??偨Y(jié)出了一些jquery選擇器、屬性設(shè)置用法,供大家參考2013-09-09jQuery ajax提交Form表單實例(附demo源碼)
這篇文章主要介紹了jQuery ajax提交Form表單的方法,結(jié)合實例分析了jQuery ajax操作實現(xiàn)表單提交的相關(guān)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2016-04-04jQuery實現(xiàn)自動調(diào)整字體大小的方法
這篇文章主要介紹了jQuery實現(xiàn)自動調(diào)整字體大小的方法,涉及jQuery針對頁面屬性與樣式動態(tài)操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06jQuery實現(xiàn)鼠標滑過預(yù)覽圖片大圖效果的方法
這篇文章主要介紹了jQuery實現(xiàn)鼠標滑過預(yù)覽圖片大圖效果的方法,涉及jQuery鼠標事件響應(yīng)及頁面元素屬性動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-04-04