感谢您的帮助。我已经努力确保其他一切正常,所以我可以专注于这个问题。我们仍然相信,一旦我们破解它,它将是一个简单的解决方案。我有以下代码,抱歉我改变了这么多,我不得不重新开始,因为我在没有备份的情况下弄糟了。
public IActionResult Index()
{
if(IndexModel.GlobalTasks == null)
{
IndexModel initModel = new IndexModel();
initModel.AllTasks = InitList();
initModel.EmptyTask = new ToDoTask();
IndexModel.GlobalTasks = initModel.AllTasks;
}
IndexModel model = new IndexModel();
model.AllTasks = IndexModel.GlobalTasks;
model.EmptyTask = new ToDoTask("");
return View(model);
}
//Create Task
public IActionResult Create(ToDoTask indexModel)
{
IndexModel.GlobalTasks.Add(indexModel);
return RedirectToAction("Index");
}
和
@model DE.Models.IndexModel
<h2>To Do List</h2>
<form asp-action="Create">
<input asp-for="EmptyTask" value="@Model.EmptyTask" />
<input asp-for="EmptyTask.TaskDetails" placeholder="New Task" />
<button type="submit">Add Task</button>
</form>
好消息是这会创建一个新的ToDoTask。因此,控制器代码必须非常接近现场。问题是View将null详细信息传递给控制器,因此我得到一个空的Task,这不是我想要的。 有什么想法吗?
答案 0 :(得分:1)
当您的视图使用ToDoTask
对象时,您的控制器操作需要TaskViewModel
个对象。
尝试在两者中使用相同的类型。
答案 1 :(得分:0)
我认为,在Create()
方法中,您需要实例化ToDoTask
对象。所以试试这个:
[HttpPost]
public IActionResult Create(ToDoTask newTask)
{
newTask = new ToDoTask();
return RedirectToAction("Index");
}
您可能还需要返回ToDoTask
对象。
答案 2 :(得分:0)