我将表单放置在 Bootstrap 模型中,当用户单击提交按钮时,我想将表单数据推送到TaskList
.
但是,当用户单击表单中的提交按钮时,formdata 不会被推送到TaskList
并被重定向到另一个页面,例如Link和 ngSubmit 也不起作用。
如果我删除类型脚本文件中的“TaskList”推送代码,表单 ngSubmit
工作正常,我得到表单数据,两种情况下我都没有收到任何错误。
如何从我的表单中获取数据并推送到TaskList
数组 ob 对象。
TS:
export class TodoListComponent {
TaskList : Task[];
name:string;
onAddtask(form : NgForm){
console.log(form);
this.TaskList.push({
id:this.TaskList.length+1,
title:form.value.taskname,
description:form.value.description,
due:form.value.duedate,
done:false
});
}
}
interface Task {
id: number;
title: string;
description?: string,
due?: string,
done: boolean
}
HTML:
<div class="well well-sm">
<h1>Todos</h1>
<button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#addTaskModel">+ Add</button>
<!-- Modal -->
<div class="modal fade" id="addTaskModel" role="dialog">
<div class="modal-dialog modal-md">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title">Modal Header</h4>
</div>
<div class="modal-body">
<form (ngSubmit)="onAddtask(addtask.value)" #addtask="ngForm">
<div class="form-group">
<label for="taskname">Task Name:</label>
<input type="text" class="form-control" id="taskname" name="taskname" ngModel>
</div>
<div class="form-group">
<label for="description">Task Description</label>
<textarea col="6" rows="6" class="form-control" name="description" ngModel></textarea>
</div>
<div class="form-group">
<label for="duedate">Due Date</label>
<input class="form-control" type="date" name="duedate" ngModel>
</div>
<button type="reset" class="btn btn-danger">Clear</button>
<button type="submit" class="btn btn-primary">Submit</button>
</form>
</div>
</div>
</div>
</div>
<!-- Model End Here-->
</div>