gpt4 book ai didi

Angular 多重拖放 (ng2-dragula)

转载 作者:行者123 更新时间:2023-12-04 03:01:34 24 4
gpt4 key购买 nike

我正在寻找支持多重拖放的拖放库。但我找不到任何 Angular 2+。 ng2-dragula 支持我们想要的,除了多次拖放。任何人都可以建议任何图书馆或如何覆盖 ng2 dragula 来实现同样的目标。 以下是我们正在寻找的功能:

  1. 拖动到目标容器中的特定位置
  2. 拖动多个项目
  3. 拖入同一个容器
  4. 适用于任何类型的元素
  5. 支持复制和移动到目标

最佳答案

基于 this commentgithub bevacqua/dragula issue: Drag and drop multiple items #50 .

我做了一些改进,允许通过选定项目拖放多个项目:https://jsfiddle.net/twfcd5hx/1/

在 ng2-dragula 上:https://stackblitz.com/edit/ng2-dragula-base-i41w6c?file=src/app/app.component.ts

相关代码(注意 I've tried using the pure angular way 但没有按预期工作,一旦我找到纯 Angular 代码就会更新):

this.dragulaService.cloned("dnd").subscribe(({ clone, original, cloneType }) => {
this.mirrorContainer = $('.gu-mirror').first();
this.mirrorContainer.removeClass('ex-over');
this.selectedItems = $('.ex-over');
this.hasMultiple = this.selectedItems.length > 1 || (this.selectedItems.length == 1 && !$(original).hasClass('ex-over'));
if (this.hasMultiple) {
$('.gu-transit').addClass('ex-over');
this.selectedItems = $('.ex-over');
this.mirrorContainer.empty();
var height = 0,
width = 0;
let temp = this.mirrorContainer;
this.selectedItems.each(function (index) {
var item = $(this);
var mirror = item.clone(true);
mirror.removeClass('ex-over gu-transit');
temp.append(mirror);
temp.css('background-color', 'transparent');
item.addClass('gu-transit');
var rect = item[0].getBoundingClientRect();
height += rect.height;
width = rect.width;
});
this.mirrorContainer = temp;
this.mirrorContainer.css('height', height + 'px');
}
});

您需要在 .ts 文件上声明 import $ from 'jquery'; 并安装 @types/jquery, jquery

解释:

this.mirrorContainer = $('.gu-mirror').first(); 获取dragula默认创建的镜像容器

this.mirrorContainer.removeClass('ex-over'); 多选项目会有这个类,但我们不希望它出现在镜像中的项目上

this.selectedItems = $('.ex-over');获取多选项

this.hasMultiple = this.selectedItems.length > 1 || (this.selectedItems.length == 1 && !$(original).hasClass('ex-over')); 检查是否选择了多个项目,并考虑他们从没有选择的项目开始拖动的位置'被选中

if (this.hasMultiple) { // we have multiple items selected
$('.gu-transit').addClass('ex-over'); // edge case: if they started dragging from an unselected item, adds the selected item class
this.selectedItems = $('.ex-over'); // update list of selected items in case of edge case above
this.mirrorContainer.empty(); // clear the mirror container, we're going to fill it with clones of our items
var height = 0,
width = 0; // will track final dimensions of the mirror container
let temp = this.mirrorContainer; // used to temporary store this.mirrorContainer since otherwise would return undefined
this.selectedItems.each(function (index) { // clone the selected items into the mirror container
var item = $(this); // the item
var mirror = item.clone(true); // clone the item
mirror.removeClass('ex-over gu-transit'); // remove the state classes if necessary
temp.append(mirror); //add the clone to mirror container
temp.css('background-color', 'transparent');
item.addClass('gu-transit'); //add drag state class to item
var rect = item[0].getBoundingClientRect(); // update the dimensions for the mirror container
height += rect.height;
width = rect.width;
});
this.mirrorContainer = temp; // restore this.mirrorContainer value after updated
this.mirrorContainer.css('height', height + 'px'); //set final height of mirror container
}

请注意,在下面的代码中,我使用了 el.remove() 来删除存储到目标元素的拖动元素,因为我已经执行了 moveback()moveto() 函数(related explanation)。

this.dragulaService.drop("dnd")
.subscribe(({ name, el, target, source, sibling }) => {
if (source.attributes[2].value === "data" && (target.attributes[3].value === "ct" || target.attributes[2].value === "target")) {
if (this.target.length > 0) {
this.placeholdertarget = false;
}
if (this.data.length < 1) {
this.placeholderdata = true;
}
if (!this.hasMultiple) {
let target = document.getElementsByClassName('target');
for (let i = target.length - 1; i >= 0; i--) {
if (target[i].className.includes('ex-over') && i >= 0) {
this.removeClass(target[i], 'ex-over');
}
}
} else {
el.remove();
this.moveto();
}
for (let i = 0; i < this.target.length; i++) {
this.target[i].state = false;
}
this.challtarget = false;
} else if (source.attributes[2].value === "target" && (target.attributes[3].value === "cd" || target.attributes[2].value === "data")) {
if (this.target.length < 1) {
this.placeholdertarget = true;
}
if (this.data.length > 0) {
this.placeholderdata = false;
}
if (!this.hasMultiple) {
let target = document.getElementsByClassName('data');
for (let i = target.length - 1; i >= 0; i--) {
if (target[i].className.includes('ex-over') && i >= 0) {
this.removeClass(target[i], 'ex-over');
}
}
} else {
el.remove();
this.moveback();
}
for (let i = 0; i < this.data.length; i++) {
this.data[i].state = false;
}
this.challdata = false;
} else {
// console.log('spilled');
// this.dragulaService.find('dnd').drake.cancel(true);
}
});

关于Angular 多重拖放 (ng2-dragula),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48745177/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com