1

我将表单放置在 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">&times;</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>
4

0 回答 0