获取被删除元素的名称和ID

mar*_*rk 4 drag-and-drop typescript angular-material angular angular-cdk

我正在使用 cdk 拖放库来拖放对象。

我的问题是我无法获取被丢弃对象的数据(对象信息:名称和 ID)。

我试过使用,console.log (event.item.data)但它给出了未定义的。

有谁知道我如何获取有关已删除元素的信息?

谢谢

Stackblitz - 演示

.ts

 drop(event: CdkDragDrop<string[]>) {
    console.log(event.item.data)
    if (event.previousContainer === event.container) {
      moveItemInArray(
        event.container.data,
        event.previousIndex,
        event.currentIndex
      );
    } else {
      transferArrayItem(
        event.previousContainer.data,
        event.container.data,
        event.previousIndex,
        event.currentIndex
      );
    }
  }
Run Code Online (Sandbox Code Playgroud)

html

<div class="six" style=" height: 75%;">
  <div class="card-deck cardsZone">
    <div class="card myCards">
      <div class="card-body" style="overflow-y: auto;"  #activeList="cdkDropList"
      class="box-list" style="height:100%"
      cdkDropList
      cdkDropListOrientation="vertical"
      [cdkDropListData]="A"
      [cdkDropListConnectedTo]="[inactiveList]"
      (cdkDropListDropped)="drop($event)">
        <div *ngFor="let nw of A" cdkDrag>
        <div class="card mysmallCcards">             
          <div class="card-body">
                   <span>{{nw.name}}</span>         
          </div>
        </div>
        </div>
      </div>
    </div>
    <div class="card myCards">
      <div class="card-body" style="overflow-y: auto;" #inactiveList="cdkDropList"
      class="box-list" style="height:100%"
      cdkDropList
      cdkDropListOrientation="vertical"
      [cdkDropListData]="B"
      [cdkDropListConnectedTo]="[activeList]"
      (cdkDropListDropped)="drop($event)">
        <div *ngFor="let pr of B" cdkDrag>
        <div class="card mysmallCcards">
          <div class="card-body">
           <span>{{pr.name}}</span>
          </div>
        </div>
        </div>
      </div>
    </div>
  </div>
</div>
Run Code Online (Sandbox Code Playgroud)

Lea*_*lla 6

试试这个:

event.previousContainer.data[event.previousIndex]

如果您想要项目的 id:

event.previousContainer.data[event.previousIndex]['id]


Fre*_*ddy 5

项目的数据只是一个输入。它的文档是:

@Input('cdkDragData') 数据:T

附加到此拖动实例的任意数据。

因此,要将数据添加到事件中,您必须为每个可拖动元素设置它。像这样:

<div *ngFor="let nw of A" cdkDrag [cdkDragData]="nw">