jQuery拖動(dòng)元素并對(duì)元素進(jìn)行重新排序
本文實(shí)例講述了jQuery拖動(dòng)元素并對(duì)元素進(jìn)行重新排序的實(shí)現(xiàn)方法,分享給大家供大家參考,具體實(shí)現(xiàn)內(nèi)容如下
效果圖:
具體內(nèi)容如下:
從上圖可以看出我們今天要實(shí)現(xiàn)的功能。當(dāng)用戶拖動(dòng)一個(gè)圖片時(shí),就能改變圖片的已有排序并更新表中的排列順序。比如用戶可以隨意拖動(dòng)我們網(wǎng)站中的布局,如谷歌iGoogle就已經(jīng)實(shí)現(xiàn)了。這樣便很好的提高了用戶體驗(yàn)。
下邊,我們一步一步來(lái)實(shí)現(xiàn)這個(gè)功能。
<span id="show"> <div> <input id="check" type="checkbox" /> </div> <div> <input type="hidden" id="orderlist" /> <ul id="list"> <asp:Repeater ID="rptOrder" runat="server"> <ItemTemplate> <li id="<%#Eval("ID") %>" title="<%#Eval("OrderID") %>"> <img alt="img" src="<%#Eval("Link") %>" /> </li> </ItemTemplate> </asp:Repeater> </ul> </div>
有一個(gè)單選框,當(dāng)用戶選中后,拖動(dòng)圖片時(shí)對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)排序進(jìn)行更改。隱藏域保存原來(lái)的圖片排列順序。ul顯示圖片列表。
為了能看得過(guò)去,稍微加了點(diǎn)樣式:
var show = jQuery("#show"); //輸出提示 var orderlist = jQuery("#orderlist"); //原順序 var check = jQuery("#check"); //是否更新到數(shù)據(jù)庫(kù)
首先將常用的選擇器保存下來(lái),這樣后邊調(diào)用就變得比較簡(jiǎn)潔。這一部大家肯定沒(méi)有問(wèn)題。^_^
//保存原來(lái)的排列順序 var order = []; list.children("li").each(function() { order.push(this.title); //原排列順序保存在title,得到后更改title jQuery(this).attr("title", "你可以拖動(dòng)進(jìn)行排序"); }); orderlist.val(order.join(','));
保存原來(lái)的排列順序到隱藏域。這里用到了數(shù)組的push()方法,就是將ul每個(gè)li中的title(原來(lái)的排列順序)添加到數(shù)組中。最后用join()方法,得到了原排列順序,返回一個(gè)字符串?,F(xiàn)在排列順序格式為1,2,3 。
//ajax更新 var Update = function(itemid, itemorder) { jQuery.ajax({ type: "post", url: "update.aspx", //id:新的排列對(duì)應(yīng)的ID,order:原排列順序 data: { id: itemid, order: orderlist.val() }, beforeSend: function() { show.html("正在更新"); }, success: function() { show.html("更新成功"); } }); };
接下來(lái),將ajax更新塊單獨(dú)分出來(lái)。這樣程序變得比較整潔,這塊沒(méi)有新東西。
//調(diào)用ajax更新方法 var Submit = function(update) { var order = []; list.children("li").each(function() { order.push(this.id); }); var itemid = order.join(','); //如果單選框選中,則更新表中排列順序 if (update) { Update(itemid); } else { show.html(""); } };
和得到排列順序類似,將ID組成一個(gè)字符串傳遞給了Update()方法。函數(shù)中的參數(shù)update為checkbox是否選中。
//執(zhí)行排列操作 list.sortable({ opacity: 0.7, update: function() { Submit(check.attr("checked")); } });
最后,執(zhí)行排列操作。后臺(tái)部分就是對(duì)現(xiàn)在ID對(duì)應(yīng)原來(lái)排列順序的更新,相信大家并不陌生。
可以看出如果不進(jìn)行數(shù)據(jù)庫(kù)操作,該插件只需要調(diào)用sorttable便可完成對(duì)元素的拖動(dòng)。
以上就是jQuery拖動(dòng)元素并對(duì)元素進(jìn)行重新排序的實(shí)現(xiàn)方法,希望對(duì)大家的學(xué)習(xí)有所幫助。
- jquery實(shí)現(xiàn)表格行拖動(dòng)排序
- jQuery-ui插件sortable實(shí)現(xiàn)自由拖動(dòng)排序
- 針對(duì)后臺(tái)列表table拖拽比較實(shí)用的jquery拖動(dòng)排序
- jQuery仿360導(dǎo)航頁(yè)圖標(biāo)拖動(dòng)排序效果代碼分享
- jquery實(shí)現(xiàn)的鼠標(biāo)拖動(dòng)排序Li或Table
- jquery對(duì)元素拖動(dòng)排序示例
- 基于JQuery的列表拖動(dòng)排序?qū)崿F(xiàn)代碼
- jQuery實(shí)現(xiàn)移動(dòng)端懸浮拖動(dòng)效果
- jQuery實(shí)現(xiàn)的簡(jiǎn)單對(duì)話框拖動(dòng)功能示例
- jquery+css實(shí)現(xiàn)移動(dòng)端元素拖動(dòng)排序
相關(guān)文章
修改jquery里的dialog對(duì)話框插件為框架頁(yè)(iframe) 的方法
為什么我不直接用modal form來(lái)做呢?所以我就做了個(gè)jquery下面dialog的插件,需要引用原來(lái)dialog的文件。2010-09-09用JQuery實(shí)現(xiàn)全選與取消的兩種簡(jiǎn)單方法
本篇文章主要是對(duì)JQuery實(shí)現(xiàn)全選與取消的兩種簡(jiǎn)單方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02jquery編寫Tab選項(xiàng)卡滾動(dòng)導(dǎo)航切換特效
這篇文章主要為大家詳細(xì)介紹了jquery編寫Tab選項(xiàng)卡滾動(dòng)導(dǎo)航切換特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-04-04基于jQuery Ajax實(shí)現(xiàn)下拉框無(wú)刷新聯(lián)動(dòng)
這篇文章主要為大家詳細(xì)介紹了基于jQuery Ajax實(shí)現(xiàn)下拉框無(wú)刷新聯(lián)動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12