jQuery ui中sortable draggable droppable的使用

来源:https://www.cnblogs.com/lvonve/archive/2020/07/23/13367038.html
-Advertisement-
Play Games

最近工作中用到了jQuery UI中排序和拖拽功能,花了大概一天的時間,搞清楚了大概的參數配置,以及遇到的一些問題,總結如下。 sortable 簡單的配置如下: $('#subs-box').sortable({ axis: 'y', cursor: 'ns-resize', placeholde ...


最近工作中用到了jQuery UI中排序和拖拽功能,花了大概一天的時間,搞清楚了大概的參數配置,以及遇到的一些問題,總結如下。

sortable

簡單的配置如下:

$('#subs-box').sortable({
    axis: 'y',
    cursor: 'ns-resize',
    placeholder: "ui-state-highlight", // 排序過程中占位符的class樣式設置
    forcePlaceholderSize: true, // 強迫占位符有一個尺寸大小。
    handle:'.sort-at', // 在對象內指定的元素上開始拖動,而不是整個元素都可以拖動
    distance: 10,
    opacity: 0.8,
    containment:'parent', // 元素可以拖動排序的範圍
    // helper: 'clone', // 是否clone一個元素進行拖動
    items: '.subject',  // 指定哪些元素可以排序
    stop: function (e, ui) {
        // 排序後元素的順序(前提每個元素都需要有id屬性)
        let newSubArr = $("#subs-box").sortable('toArray'); 
        console.log(newSubArr);
    },
}).disableSelection(); // 拖動時禁止選中元素

還有一些排序時候的事件和方法,都在參考鏈接的文檔裡面。

draggable

dragInit() {
    let me = this;
    let selector = '.ptype-'+me.selectedSubType;
    
    // 題目拖動
    $('#subs-box .subject').draggable({
        // appendTo: ".ptype-item.radio", // 當進行拖動時,拖動組件助手應該被添加到的元素。
        // connectToSortable: "#subs-box", // 允許draggable被拖拽到指定的sortables中。
        
        // 拖動時使用的是clone的元素。如果值設置為"clone", 那麼該元素將會被覆制,並且被覆制的元素將被拖動。
        // 之所以不使用 helper: 'clone', 是因為clone的元素沒有樣式,所以我們需要自定義樣式,所以使用了自定義函數。
        helper: function() {
            let helper = $(this).clone();
            helper.css({'width': $(this).width(), 'background': '#fff'}); // 設置clone元素的樣式
            return helper;
        },
        handle: ".drag-at", // 指定在特定的元素上觸發滑鼠按下事件時,才可以拖動。
        cursor: 'move',
        // containment: '.sub-box', // 可以限制draggable只能在指定的元素或區域的邊界以內進行拖動。
        revert: 'invalid', // 如果設置為true,當拖動停止時,元素位置將被重置。
        revertDuration: 200,
        distance: 10,
        opacity: 0.8,
        zIndex: 10000,
        refreshPositions: true, // 所有的可拖動位置在每次滑鼠移動時都會被計算。(設置該值使得drop的位置更加精確)
        start(event, ui) {
            $(selector).addClass('allow'); // 元素拖拽的時候,設置可放置元素的樣式,示意你可以拖拽到那裡去
            // 開始拖拽的時候,初始化drop
            me.$nextTick(()=>{
                me.dropInit();
            });
        },
        stop(event, ui) {
            $(selector).removeClass('allow');
            // 拖拽停止的時候,銷毀drop函數。
            me.dropDestory();
        }
    }).disableSelection();

},

註意事項:

每次dropInit函數初始化後,如果需要再次初始化,需要先銷毀之前的放置對象。否則第一次初始化後,比如某個地方A可以放置拖拽的元素,但是第二次初始化後,地方A就不可以放置了。然而實際上,如果你不把第一次初始化的dropInit函數銷毀掉,地方A在第二次初始化後還是可以放置的。所以需要在拖拽停止的時候,銷毀上一次的dropInit對象。

dropable

dropInit() {
    let me = this;
    // 題目放置(設置題目根據不同類型可以放置不同的分頁)
    // selector是可變的,也就是每次可拖拽元素可放置的元素是不同的。所以需要每次拖拽後清除之前dropInit對象。
    let selector = '.ptype-'+me.selectedSubType;

    $(selector).droppable({
        // accept: selector,
        // accept: function(d) {
        //     if($(this).hasClass('ptype'+me.selectedSubType)){
        //         console.log('d>>>>>>',$(this)[0]);
        //         return true;
        //     }
        // },
        // hoverClass: "drop-hover",
        tolerance: 'pointer', // 指定使用那種模式來測試一個拖動(draggable)元素"經過"一個放置(droppable)對象
        drop: function( event, ui ) {
            // $(this) 填充到的元素
            // ui.draggable.context 填充的元素
            let dragId = $(ui.draggable.context).attr('id');
            let dropId = $(this).attr('id');

            // 移動到新的分頁
            if(dropId === 'newpage') {
                me.moveAddPage(dragId);
            } else { // 移動題目到另一個分頁
                if(dropId === me.selectedPage.id) { // 移動到自己的分組,不做處理

                } else {
                    let index = me.selectedPage.subs.indexOf(dragId);
                    if(index > -1) {
                        me.selectedPage.subs.splice(index, 1);

                        me.pages.forEach(page=>{
                            if(page.id === dropId) {
                                page.subs.push(dragId);
                            }
                        });

                        me.$openNotice('移動成功');
                        
                        // 其他操作...
                    }
                }
            }

            $(this).removeClass('allow-hover');
        },
        over(event, ui) {
            $(this).addClass('allow-hover'); // 當拖拽元素進入可放元素時,可放置元素本身的樣式
        },
        out() {
            $(this).removeClass('allow-hover'); // 設置拖拽元素離開可放元素時,清除可放置元素本身的樣式
        }
    });
},
dropDestory() {
    let selector = '.ptype-'+me.selectedSubType;
    $(selector).droppable("destroy");
},

參考鏈接


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

-Advertisement-
Play Games
更多相關文章
  • 快速反饋對於任何 UI 的實現都是至關重要的。研究表明,100ms 是界面讓用戶感到即時的最大延遲。儘管如此,移動網路仍然受到一個巨大的反饋問題的困擾:觸摸任何元素後,延遲 300 毫秒。這種延遲是許多用戶認為基於 HTML 的 Web 應用程式“卡頓”的最重要原因之一。在本文中,本文將帶你瞭解移動... ...
  • 一個網站建立以後,如果不註意安全方面的問題,很容易被人攻擊,下麵就討論一下幾種漏洞情況和防止攻擊的辦法。 一、SQL註入 所謂SQL註入,就是通過把SQL命令插入到Web表單提交或輸入功能變數名稱或頁面請求的查詢字元串,最終達到欺騙伺服器執行惡意的SQL命令。具體來說,它是利用現有應用程式,將(惡意)的SQ ...
  • 通過 javascript 偽協議, HTML5 dialog 元素實現的分屏書簽程式 ...
  • 俗話說,出來江湖混的,持善良之心,懷正義之氣,總有志同道合者共相為謀。而HTML也有這麼幾個大哥們er、小兄dei、小寶貝兒。他們一起乾大事,為服務好普羅大眾貢獻自己一份力量,接下來讓我們一起走進他們吧。 ...
  • 什麼是 DOM? 如果我們把這個 HTML 載入到瀏覽器中,瀏覽器創建這些節點,用來顯示網頁。所以這個HTML映射到一系列DOM節點,然後我們可以使用JavaScript進行操作。例如: let item = document.getElementByTagName('h1')[0] item.te ...
  • 微信端返回按鈕 WeixinJSBridge.call('closeWindow'); $("#close").click(function(){ setTimeout(function(){WeixinJSBridge.call('closeWindow');},1000); }) ...
  • BOM(瀏覽器對象模型)簡介、window對象、location對象、history對象、navigator對象、screen對象、document對象 ...
  • 效果圖看左上角 代碼如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>基於CSS3的3D立方體旋轉動畫</title> <style> /* 3d旋轉樣式 */ .cub { width: 2.5rem; height: ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...