- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Angular 6 和 NGX-Bootstrap
我有一个组件和服务,在访问页面时,我使用 Nodejs 和 Mongoose 从 mongodb 数据库中检索所有“位置”。
我循环了 http get 调用的结果,并将“位置”的名称放入表中。在表格的右侧以及填充表格的循环的一部分 (ngFor),我添加了一个删除按钮。我想让用户单击该按钮,然后在删除之前收到警报模式提示。我的问题是将位置 ID 传递给模态,然后模态可以调用删除函数并传回 ID(mongodb 对象 id)
我很难弄清楚如何移动这些数据,因为我相信 ngFor 循环只包含对该范围的 ID 的引用,但模态是由 templateRef 加载的,并且该函数不会采取另一个可通过的方法作为第二个参数输入。
非常感谢任何帮助
----组件
import { Component, OnInit, TemplateRef } from '@angular/core';
import { LocationService } from '../services/location.service';
import { Observable } from 'rxjs';
import { BsModalService } from 'ngx-bootstrap/modal';
import { BsModalRef } from 'ngx-bootstrap/modal/bs-modal-ref.service';
import { Location } from '../models/location.model';
import { NgForm } from '@angular/forms';
@Component({
templateUrl: './location.component.html',
styleUrls: ['./location.component.css']
})
export class LocationComponent implements OnInit {
public locations: Location[] = [];
addLocationForm = false;
modalRef: BsModalRef;
constructor(private locationService: LocationService, private modalService: BsModalService) {}
ngOnInit() {
this.locationService.loadAll().subscribe(result => {
this.locations = result;
});
}
showLocationForm() {
this.addLocationForm = !this.addLocationForm;
}
onSaveLocation(form: NgForm) {
if (form.invalid) {
return;
}
const location = {
name: form.value.name
};
this.locationService.saveLocation(location).subscribe(result => {
this.ngOnInit();
this.addLocationForm = !this.addLocationForm;
});
}
deleteLocation(id) {
this.locationService.deleteLocation(id).subscribe(result => {
console.log('Deleted location from inside the delete location function', id);
this.ngOnInit();
});
}
openModal(template: TemplateRef<any>) {
this.modalRef = this.modalService.show(template, { class: 'modal-sm' });
}
confirm(): void {
this.deleteLocation('10');
this.modalRef.hide();
}
decline(): void {
this.modalRef.hide();
}
}
----模板
<table class="table table-hover table-bordered">
<thead class="thead bg-info text-white">
<tr>
<th style="width: 85%" scope="col">Locations</th>
<th scope="col">Action</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let loc of locations">
<td>{{ loc.name | titlecase }}</td>
<td>
<button class="actionBtn btn btn-warning">
<i class="fa fa-pencil-square-o"></i>
</button>
<button class="btn btn-danger" (click)="openModal(template)">
<i class="fa fa-times"></i>
</button>
</td>
</tr>
</tbody>
</table>
<button class="btn btn-info" (click)="showLocationForm()">Add Location</button>
<ng-template #template>
<div class="modal-header">
<h4 class="modal-title pull-left">Delete Location</h4>
<button type="button" class="close pull-right" aria-label="Close" (click)="modalRef.hide()">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body text-center">
<p>Do you really want to delete this location?</p>
<button type="button" class="btn btn-primary" (click)="decline()">Cancel</button>
<button type="button" class="btn btn-default" (click)="confirm()">Delete</button>
</div>
</ng-template>
最佳答案
import { Component, OnInit, TemplateRef } from '@angular/core';
import { LocationService } from '../services/location.service';
import { Observable } from 'rxjs';
import { BsModalService } from 'ngx-bootstrap/modal';
import { BsModalRef } from 'ngx-bootstrap/modal/bs-modal-ref.service';
import { Location } from '../models/location.model';
import { NgForm } from '@angular/forms';
@Component({
templateUrl: './location.component.html',
styleUrls: ['./location.component.css']
})
export class LocationComponent implements OnInit {
public locations: Location[] = [];
addLocationForm = false;
modalRef: BsModalRef;
constructor(private locationService: LocationService, private modalService: BsModalService) {}
ngOnInit() {
this.locationService.loadAll().subscribe(result => {
this.locations = result;
});
}
showLocationForm() {
this.addLocationForm = !this.addLocationForm;
}
onSaveLocation(form: NgForm) {
if (form.invalid) {
return;
}
const location = {
name: form.value.name
};
this.locationService.saveLocation(location).subscribe(result => {
this.ngOnInit();
this.addLocationForm = !this.addLocationForm;
});
}
deleteLocation(id) {
this.locationService.deleteLocation(id).subscribe(result => {
console.log('Deleted location from inside the delete location function', id);
this.ngOnInit();
});
}
openModal(template: TemplateRef<any>, data) {
this.locationData = data
this.modalRef = this.modalService.show(template, this.locationData);
}
confirm(data): void {
this.deleteLocation(data.id);
this.modalRef.hide();
}
decline(): void {
this.modalRef.hide();
}
}
模板
<table class="table table-hover table-bordered">
<thead class="thead bg-info text-white">
<tr>
<th style="width: 85%" scope="col">Locations</th>
<th scope="col">Action</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let loc of locations; let index=index">
<td>{{ loc.name | titlecase }}</td>
<td>
<button class="actionBtn btn btn-warning">
<i class="fa fa-pencil-square-o"></i>
</button>
<button class="btn btn-danger" (click)="openModal(template, loc)">
<i class="fa fa-times"></i>
</button>
</td>
</tr>
</tbody>
</table>
<button class="btn btn-info" (click)="showLocationForm()">Add Location</button>
<ng-template #template>
<div class="modal-header">
<h4 class="modal-title pull-left">Delete Location</h4>
<button type="button" class="close pull-right" aria-label="Close" (click)="modalRef.hide()">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body text-center">
<p>Do you really want to delete this location {{locationData.name}}?</p>
<button type="button" class="btn btn-primary" (click)="decline()">Cancel</button>
<button type="button" class="btn btn-default" (click)="confirm(locationData)">Delete</button>
</div>
</ng-template>
将这样的数据传递给模型。
关于javascript - 如何将 ID 传递给 ngx-bootstrap 模式以进行删除确认,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53147148/
TCP header 上的 32 位确认字段,比如 x告诉另一台主机“我收到了所有字节,直到并包括 x-1,现在期待来自 x 和 on 的字节”。在这种情况下,接收方可能已经收到了一些更多字节,比如
我正在使用 PyCharm 2020.2.3 不知不觉中我点击了下图中的复选框 现在,即使我的代码正在调试中,点击运行也会终止调试并开始运行代码。如何将其恢复为未选中状态?谢谢。 PS:我的“允许并行
我想知道何时使用 RabbitMQ 和 Spring Boot 接受 (ack) 或不接受 (nack) 消息。 我想将消息发送到队列(通过交换)并检查队列是否已接受该消息。实际上我想发送到两个不同的
我一直在寻找一种方法让用户确认 票在分配给他们之后。不知道有没有 这是一个内置功能,或者如果有一个插件 将为用户创建一个状态/按钮以接受票证 在它被放入队列之后。我希望 从附近的售票窗口看到类似的东西
我正在构建一个应用程序以通过 Xbee API 与 Xbee 模块通信。 目前我有一些工作,但它相当简单并且有很多限制。 Sub processPackets() ' this runs as its
我有一个复选框,更改后会自动发布。 自动发布对于两者(选中和未选中)都适用,但我想在每个事件发生之前弹出一个对话框进行确认。 到目前为止,当选中该复选框时,弹出框就会起作用。 但当取消选中该复选框时,
当我使用 UIGestureRecognizer ,例如,当用户向右滑动时,我想要一个 UIAlertView询问他是否真的要进行向右滑动的 Action 。 我曾尝试这样做,但没有成功。 最佳答案
我有一个 asp:CheckBoxList,我想显示一条警告消息仅在使用 jquery 取消选中复选框时。 $('.chklist').click( function () {
我想知道有什么可能的方法来确定我们的推送消息是否最终从 APNS 服务器传送。我已经想出了一些信息,如下所述 APNS 正在发送接受推送请求的响应代码,并可能给出错误代码(如果有)。例如:如果您的有效
我有此页面,我正在尝试确认输入文本字段中的日期与当前日期。如果输入字段中的日期晚于当前日期,则需要出现确认框以确认他们输入了正确的日期。因此,“确定”按钮需要完成数据提交,“取消”按钮需要将它们返回到
我有一个功能: function placeOrder(price, productList) { var bulletinBoardItem = Number(productList.box
我不明白为什么即使我点击“否”,这个confirm()调用也会被触发。你能告诉我我做错了什么吗? $('.deleteButton').livequery('click',function(){
我目前正在使用 dotmailer 生成一个新表单(简单的文本框和提交按钮),自动将电子邮件地址添加到 dotmailer 地址簿。 当有人提交电子邮件地址时 - 他们可以被带到网页。 我一直在尝试
这是不起作用的代码...它只是删除表单而不先提示。 $(".delete").click(function () { if(confirm('You honestly want to dele
我在我的程序中使用 aprgeparse 创建一个参数,允许用户从 amazon s3 存储桶中删除文件。我以这种方式创建它: parser.add_argument("-r", "--remove"
我正在努力学习 puppeteer 操作。我已经成功编写了登录页面和一些导航的脚本。然后我让它点击一个按钮。该页面抛出一个 window.confirm,我希望我的脚本接受它以继续下一步,但我不知
某网站实现了一个第三方插件,提示用户在删除前进行确认。 confirmDelete: function (event) { var go_ahead = confirm("Are you su
我想在 primefaces 的选择/取消选择复选框上显示确认对话框。我试过了 但它不起作用,因为 selectBooleanCheckBox 不可确认。是否有解决此问题的解决方法? 最
我们已经从 TFS 下载了一个项目,在恢复 Nuget 包后,我们收到以下错误: Error 5 The "ValidatePackageReferences" task could not
我有两个单独的 ul 列表:列表 A 和列表 B 由于 jQuery UI 插件,它们都可以排序。 我正在开发的项目的用户希望在项目从一个列表移动到另一个列表时确认操作,但在同一列表内移动时则不需要。
我是一名优秀的程序员,十分优秀!