dragsort html拖拽排序

来源:http://www.cnblogs.com/always-online/archive/2016/01/26/5160475.html
-Advertisement-
Play Games

一、Jquery List DragSort 對於有些頁面,如首頁的定製,需要進行動態的拖拽排序。由於自己實現比較困難,我們一般會使用一些js插件來實現。dragsort 就是幫助我們完成這一需求。通過dragsort我們可以很方便地對html頁面上的素動態地推拽,進行排序。dragsort是一.....


一、Jquery List DragSort
  對於有些頁面,如首頁的定製,需要進行動態的拖拽排序。由於自己實現比較困難,我們一般會使用一些js插件來實現。dragsort 就是幫助我們完成這一需求。通過dragsort我們可以很方便地對html頁面上的素動態地推拽,進行排序。dragsort是一個jquery插件,我們使用起來非常方便。dragsort網站為:dragsort下載地址為:http://dragsort.codeplex.com/
下載dragsort之後,解壓如下圖所示,

  

  我們使用到的只有裡面的jquery.dragsort-0.5.2.js這個文件,也可以使用壓縮版的min.js。
二、實例
  1、使用
  將jquery.dragsort-0.5.2.js,與jquery-2.1.3.min.js拷貝到同一個文件夾,新建html頁面。引入這兩個js文件。註意jquery在dragsort上面引入。相關代碼如下:

 

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4     <title>拖拽示例</title>
  5     <meta charset="utf-8" />
  6     <style type="text/css">
  7         body { font-family:Arial; font-size:12pt; padding:20px; width:820px; margin:20px auto; border:solid 1px black; }
  8         h1 { font-size:16pt; }
  9         h2 { font-size:13pt; }
 10         ul { margin:0px; padding:0px; margin-left:20px; }
 11         #list1, #list2 { width:350px; list-style-type:none; margin:0px; }
 12         #list1 li, #list2 li { float:left; padding:5px; width:100px; height:100px; }
 13         #list1 div, #list2 div { width:90px; height:50px; border:solid 1px black; background-color:#E0E0E0; text-align:center; padding-top:40px; }
 14         #list2 { float:right; }
 15         .placeHolder div { background-color:white !important; border:dashed 1px gray !important; }
 16     </style>
 17     <script type="text/javascript" src="jquery-2.1.3.min.js"></script>
 18     <script type="text/javascript" src="jquery.dragsort-0.5.2.min.js"></script>
 19 </head>
 20 <body>
 21     
 22     <h1>示例</h1>     
 23     <script type="text/javascript">
 24         $("ul:first").dragsort();
 25     </script>
 26     
 27     <h2>可以在兩個分組直接進行拖拽</h2>
 28     
 29     <ul id="list2" class="draglist"  data-groupid="gid-2">
 30         <li data-id="10" data-groupid="gid-2"><div>10</div></li>
 31         <li data-id="11" data-groupid="gid-2"><div>11</div></li>
 32         <li data-id="12" data-groupid="gid-2"><div>12</div></li>
 33         <li data-id="13" data-groupid="gid-2"><div>13</div></li>
 34         <li data-id="14" data-groupid="gid-2"><div>14</div></li>
 35         <li data-id="15" data-groupid="gid-2"><div>15</div></li>
 36         <li data-id="16" data-groupid="gid-2"><div>16</div></li>
 37         <li data-id="17" data-groupid="gid-2"><div>17</div></li>
 38         <li data-id="18" data-groupid="gid-2"><div>18</div></li>
 39     </ul>
 40     <input name="sortorder" id ="gid-2" type="hidden" value="10,11,12,13,14,15,16,17,18" />
 41     
 42     <ul id="list1" class="draglist" data-groupid="gid-1">
 43         <li data-id="1" data-groupid="gid-1"><div>1</div></li>
 44         <li data-id="2" data-groupid="gid-1"><div>2</div></li>
 45         <li data-id="3" data-groupid="gid-1"><div>3</div></li>
 46         <li data-id="4" data-groupid="gid-1"><div>4</div></li>
 47         <li data-id="5" data-groupid="gid-1"><div>5</div></li>
 48         <li data-id="6" data-groupid="gid-1"><div>6</div></li>
 49         <li data-id="7" data-groupid="gid-1"><div>7</div></li>
 50         <li data-id="8" data-groupid="gid-1"><div>8</div></li>
 51         <li data-id="9" data-groupid="gid-1"><div>9</div></li>
 52     </ul>
 53     <input name="sortorder" id ="gid-1" type="hidden" value="1,2,3,4,5,6,7,8,9"/>
 54     <div style="clear:both;"></div>
 55 <script type="text/javascript">
 56     $(".draglist").dragsort({
 57     dragSelector: "li",
 58     dragBetween: true,
 59     dragEnd: saveOrder, //拖拽完成後回調函數
 60     placeHolderTemplate: "<li class='placeHolder'><div></div></li>" //拖動是陰影
 61 });
 62 
 63 function saveOrder() {
 64     var $this = $(this);
 65     var data = $this.parent().children().map(function() {
 66         return $this.attr("data-id");
 67     }).get();
 68 
 69     var currentid = $this.attr("data-id"); //組件id
 70     var oldgroupid = $this.attr("data-groupid"); //所屬組id
 71     var groupid = $this.parent().attr("data-groupid"); //目標組id
 72 
 73     //跨組移動、移除舊組信息
 74     if (oldgroupid != groupid) {
 75         var oldgroup = $("#" + oldgroupid);
 76         var groupval = oldgroup.val().replace(currentid, "");
 77         oldgroup.val(groupval);
 78     }
 79 
 80     $("#" + groupid).val(data.join(",")); //添加所屬組記錄
 81     $this.attr("data-groupid", groupid); //改變所屬組id  
 82 };
 83 
 84 /**
 85  * 保存位置
 86  */
 87 function savePosition() {
 88     var inputs = $("input[name='sortorder']");
 89     var arr = new Array();
 90     //構造數據
 91     inputs.each(function() {
 92         var $this = $(this);
 93         arr.push($this.attr("id") + "-" + $this.val());
 94     });
 95     
 96     $.ajax({
 97         url: "${ctx}/test/position.json",
 98         type: "POST",
 99         data: { "tiles": arr },
100         dataType: "json",
101         success: function(data) {
102             if (data.flag)  
103                 alert("保存成功");
104             else
105                 alert("保存失敗");
106         }
107     });
108 } 
109 </script> 
110 </body>
111 </html>

  其中兩個input的值為li的id(以","連接),id值的順序標識當前分組li的排列順序。跨組拖動的時候兩個input中的值會隨之改變。從而達到跨組移動的效果。需要保存的時候,直接使用ajax將兩個input的值進行提交,後臺解析數據保存到資料庫即可。

  2、效果如下。

  示例下載:下載 。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要介紹消息隊列概述,消息隊列應用場景(非同步處理,應用解耦,流量削鋒,日誌處理,消息通訊)和消息中間件示例(電商,日誌系統)。
  • .mb{16 background-color:#9e9e9e;filter:Alpha(Opacity=60);position:absolute;opacity:0.6;top:0;left:0;z-index:10;18 }
  • 1滑鼠移上去在圖片上層添加一個蒙版 下邊附上代碼和實現效果案例 2 3 4 5 6 7 8 9 10 26 33 34 35 36 ...
  • HTML5目前最新的規範(標準)是2014年10月推出 2005年左右出現HTML5版本(非標準) W3C組織(兩個組織定義H5規範) 學習(研究)HTML5是學習未來(將來主流) HTML版本 - 第一階段主要學習還是4版本(包含5版本) HTML5版本之後,聲明不再出現版本信息 ...
  • js 節點 document html css 表單節點操作節點操作:訪問、屬性、創建(1)節點的訪問:firstChild、lastChild、childNodes、parentChild(父子節) 可以使用元素對象的方法進行代替:getElementById()、getElemen...
  • 在後臺管理系統開發的過程中,上左右的佈局是最常見的頁面佈局方式,現在我們來看看使用easyui這個jquery前端框架如何快速搭建一個可用的頁面框架。1.在頁面中引入easyui所需的文件1 2 3 4 5 6 7 2.在頁面body部分構建必要的html結構 ...
  • 通常我們這樣寫一個菜單: Orders 菜單項是否高亮顯示取決於controller中的highlight方法。vm.highlight = funciton(path){ return $locaiton.path().substr(0, path.lenght)...
  • js 隨機星星 document.createElement(); setAttribute()無標題文檔
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...