AngularMaterial拖放事件返回错误的拖动项索引并移动错误的项。
创始人
2024-10-28 11:02:42
0

这个问题通常是由于使用了Angular Material的CDK拖放库中的错误导致的。解决此问题的一种方法是使用CDK DropList中提供的data参数来传递所需的数据。

以下是一个示例代码,演示如何使用data参数来解决此问题:

HTML模板部分:

{{ item.name }}

组件部分:

import { Component } from '@angular/core'; import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';

@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { items = [ { id: 1, name: 'Item 1' }, { id: 2, name: 'Item 2' }, { id: 3, name: 'Item 3' }, { id: 4, name: 'Item 4' }, { id: 5, name: 'Item 5' } ];

onDrop(event: CdkDragDrop) { const draggedIndex = event.previousIndex; const droppedIndex = event.currentIndex; const draggedItem = event.item.data;

console.log('draggedIndex', draggedIndex);
console.log('droppedIndex', droppedIndex);
console.log('draggedItem', draggedItem);

moveItemInArray(this.items, draggedIndex, droppedIndex);

} }

在这个示例中,我们在CDK拖动事件中使用了data属性来传递所需的数据。然后,在onDrop方法中获取拖动项的数据,并使用它执行任何必要的操作。这样就能够解决Angular Material拖放事件返回错误索引和移动错误项的问题。

相关内容

热门资讯

安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...
安卓系统怎么连不上carlif... 安卓系统无法连接CarLife的原因及解决方法随着智能手机的普及,CarLife这一车载互联功能为驾...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
oppo手机安卓系统换成苹果系... OPPO手机安卓系统换成苹果系统:现实吗?如何操作?随着智能手机市场的不断发展,用户对于手机系统的需...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
安装安卓应用时出现“Play ... 在安装安卓应用时出现“Play Protect 警告弹窗”的原因是Google Play Prote...
vivo安卓系统取消更新系统,... 亲爱的vivo手机用户们,你们是不是也遇到了这样的烦恼:手机里突然冒出一个更新提示,点开一看,哇,新...
iqoo安卓14系统怎么升级系... 亲爱的iQOO手机用户们,是不是觉得你的手机系统有点儿落伍了呢?别急,今天就来手把手教你如何升级到最...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
安卓系统连接荣耀手表,操作指南... 亲爱的手机控们,是不是最近入手了一款酷炫的荣耀手表,却不知道怎么和安卓手机完美“牵手”呢?别急,今天...