- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
出于某种原因(阅读:无法创建许多组件),我必须在我的应用程序上创建能够充当放置元素的部分。 (不能使用*ngIf
)
我像这样创建了 DropListRef -
constructor(private dragDropService: DragDrop) {}
const dropListRef = this.dragDropService
.createDropList(dropZone)
.withItems([]);
我正在尝试检测元素是否已被删除为 -
dropListRef.dropped.subscribe(event => {
console.log("dropped: ");
});
但是,我从未找到控制台输出。
示例代码链接 - https://stackblitz.com/edit/angular-r3spyc
演示视频链接 - https://drive.google.com/file/d/1b6RUuOk9r7s9vFd3NlhgR9ot1hHP1Oeb/view
不能创建很多组件
dropped
、entered
等事件。感觉我错过了一些重要的步骤,比如在某处注册它或连接到另一个 DropList,然后 Angular Material 可以识别或识别它。Dropbox 组件
)是因为那样会使手头的问题过于简单化。与问题相关的复杂性太多,无法封装在单个组件中,如 Dropbox 组件
(或多个)。如果我为每个用例创建一个模板,我可能最终会创建 100 多个 ng 模板(或不同的组件)。最佳答案
您的编码方式不是典型的 Angular 编码方式。我查了Angular official site并为您做了一点调整。
我用 drop-box.component.html 创建了一个下拉框组件:
<div>{{text}}</div>
drop-box.component.ts:
import { Component, Input } from "@angular/core";
@Component({
selector: "drop-box",
templateUrl: "./drop-box.component.html",
styleUrls: ["./drop-box.component.scss"]
})
export class DropboxComponent {
@Input() text = "";
constructor() {}
}
对于您的app.component.ts:
import { Component } from "@angular/core";
import {
CdkDragDrop,
CdkDrag,
DragDropRegistry,
DragDrop,
DragRef,
moveItemInArray,
transferArrayItem
} from "@angular/cdk/drag-drop";
@Component({
selector: "app-root",
templateUrl: "./app.component.html",
styleUrls: ["./app.component.scss"]
})
export class AppComponent {
title = "angular-draggable";
previousIndex = 0;
todo = ["a", "b", "c", "d", "e"];
list = ["default item"];
isEnabled = false;
constructor(private dragDropService: DragDrop) {}
onDragStart(event, i) {
console.log("drag started!", event);
console.log('event.previousIndex',event.previousIndex);
console.log('i',i);
this.previousIndex = i;
}
createDroplist() {
this.isEnabled = !this.isEnabled;
}
drop(event: CdkDragDrop<string[]>){
if(this.isEnabled)
{
transferArrayItem(event.previousContainer.data,
event.container.data,
this.previousIndex,
event.currentIndex);
}
}
}
注意“点击我创建下拉列表”按钮和 createDroplist 方法可能不再需要了。但我把它放在那里是为了启用/禁用拖动,以防您仍然需要它。
和 app.component.html:
<div cdkDropListGroup>
<div class="example-container">
<h2>To do</h2>
<div style="position: relative;">
<ng-container *ngFor="let item of todo; let i = index">
<div cdkDropList #todoList="cdkDropList" class="example-list" [cdkDropListData]="todo" [cdkDropListConnectedTo]="[doneList]">
<div class="example-box stupid">{{item}}</div>
<div class="example-box" (cdkDragStarted)="onDragStart($event, i)" cdkDrag>{{item}}</div>
</div>
</ng-container>
</div>
</div>
<button (click)="createDroplist()">
Click me to create droplist
</button>
<div id='box' cdkDropList
#doneList="cdkDropList"
[cdkDropListData]="list"
[cdkDropListConnectedTo]="[todoList]"
(cdkDropListDropped)="drop($event)">
<div *ngFor="let item of list">
<drop-box [text]="item"></drop-box>
</div>
</div>
</div>
你可以看看我的例子here . 同样,要从待办事项列表中拖动,您现在需要先单击“单击我以创建下拉列表”按钮,然后放下。
编码愉快!
关于 Angular Material : Not able to drop on a dynamically created droplist,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59291258/
如何将多个json对象添加/映射到dart对象 import 'dart:async'; import 'dart:convert'; import 'package:flutter/foundati
我正在研究将产品集成到 Dynamics Great Plains 中。我之前使用过 Dynamics CRM,但没有使用过 Great Plains。我听说 GP 与 CRM 是不同的动物,即使它们
System.Linq.Dynamic.Core 和 System.Linq.Dynamic 有什么区别?我目前正在使用 System.Linq.Dynamic 并且它不包含对 的支持选择 和 多选
我正在尝试通过Firebase存储将图像上传到Firebase,然后在Firestore中创建一个文档,其中包含上述上传图像的网址。为此,我使用此功能 void uploadImageAndCr
我一直在尝试整理一些东西,使我可以从 ListPlot 中提取点,以便在进一步的计算中使用它们。我目前的方法是使用 Locator[] 选择点。这适用于显示点,但我无法弄清楚如何从带有 head Dy
只要我在与 Program 类相同的程序集中有类 ClassSameAssembly ,下面的代码就可以正常工作。但是,当我将类 ClassSameAssembly 移动到单独的程序集时,会引发 Ru
我只是尝试从Firebase实时数据库解析数据。 但在转换为模型时有问题 我正在尝试从Flutter上解析Firebase数据库中的数据。 但是一个错误说 MY Complete QUIZ: {-M5
我创建了一个方法,当我构建它时,出现了这个错误: type '_InternalLinkedHashMap' is not a subtype of type 'List' in type cast
我对这个 flutter 的简单图表代码有疑问。在我尝试运行代码时显示此错误。请任何人都可以帮助我在这.... The argument type 'List>' can't be assigned
我尝试在我的 flutter 应用程序中解析来自 Firestore 的文档。 Firestore 文档: 我创建了两个类来解析这个文档。 类产品: class Produkt{ String n
我有一个2d-List,其中包含一个字符串和一个Map,如下所示: List> content = [ [ "String", { "one": 23,
我使用 Dart“json_serializable”包在 Flutter 应用程序中的 Firestore 数据结构下反序列化。 { googleBookId: jjl4BgAAQBAJ, prov
我注册了 Dynamic CRM 在线试用版(30 天)并创建了一个非托管自定义解决方案(新字段、一些自定义实体等)。现在,我想导出非托管解决方案并将其导入到我的服务器中的 Dynamic CRM O
当我尝试从 StreamTransform 获取一些数据时遇到一些问题 我不明白什么是正确的数据类型 未捕获的异常:类型错误:“_StreamHandlerTransformer”的实例:“_Stre
我正在尝试获取用户数据,但在这样做时出现以下错误: Exception: type '_InternalLinkedHashMap' is not a subtype of type 'Map 我查看
我正在尝试在 sqflite 数据库中保存一些带有 flutter 的数据,但我仍然收到一条错误消息: [ERROR:flutter/shell/common/shell.cc(181)] Dart
我有一个JSON响应,结构如下:。在这个JSON响应中,有各种动态键,如“Owner”和“Master”,每个键都包含一个JSON对象或一个JSON对象数组。我需要创建一个gson数据类来解析这个动态
在 Dynamics 2012 ax 中编译 CIL 时,我看到以下错误 - 名称为“Dynamics.Ax.application”的重复类型。在程序集中“Dynamics.Ax.applicati
我有一个带有 LinkedHashMap 成员的 StatefulWidget 小部件,如下所示: LinkedHashMap _items = new LinkedHashMap>(); 现在我需要
我正在尝试按照此处所述实现搜索资源功能:https://cloudblogs.microsoft.com/dynamics365/it/2019/05/21/retrieve-resource-ava
我是一名优秀的程序员,十分优秀!