3

我是 C# 和 MVC 的新手,我是从 PHP 背景进入 Visual Studio 环境的。我正在摸索一点(很多),但到达那里。我需要帮助来理解一些基本概念,这无疑是一项非常笨拙的工作,但帮助我解决这个问题将帮助我理解事情是如何运作的。

我有一个 SQL 数据库,通过添加 ADO.NET 实体类模型连接到 VS2012 Web 项目 (C#)。可以说那端没有问题,自动生成的默认 CRUD 视图也没有问题。

用例:

我想要一个网页,向用户展示从数据库中提取的项目列表。这已经在默认的索引视图中实现了,但我还希望该列表可以在当时和那里进行编辑,而不必为每个单独的项目输入编辑视图。ActionName因此,我将列表 HTML 更改为表单,并为“更新”提交设置了一个。这也没有问题:

模型:

namespace Library3.DAL {
    using System;
    using System.Collections.Generic;
    using System.ComponentModel.DataAnnotations;

    public partial class PrmTbl_Level {
        public PrmTbl_Level() {
            this.Tbl_Books = new HashSet<Tbl_Book>();
        }

        [Required]
        [Display(Name = "ID")]
        public int LevelID { get; set; }

        [Required]
        [Display(Name = "Description")]
        public string LevelDesc { get; set; }

        [Required]
        [Display(Name = "Entered By")]
        public string EnteredBy { get; set; }

        public Boolean Active { get; set; }

        public virtual ICollection<Tbl_Book> Tbl_Books { get; set; }
    }
}

看法:

@model IEnumerable<Library3.DAL.PrmTbl_Level>


@using (Html.BeginForm("Update", "ReaderLevel", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)

<fieldset>
    <table>
        <thead>
            <tr>
                <th> @Html.DisplayNameFor(model => model.LevelID) </th>
                <th> @Html.DisplayNameFor(model => model.LevelDesc) </th>
                <th> @Html.DisplayNameFor(model => model.EnteredBy) </th>
                <th> @Html.DisplayNameFor(model => model.Active) </th>
            </tr>
        </thead>

        @foreach (var item in Model) {

            var thisID = item.LevelID;
            var thisDesc = item.LevelDesc;
            var thisEnteredBy = item.EnteredBy;
            var thisActive = item.Active;

            <tr>
                <td class="tdsm centered fade"> @thisID </td>
                <td> <input type="text" name="@(thisID + ".desc")" value="@thisDesc" /> </td>
                <td class="tdmed centered fade"> @thisEnteredBy </td>
                <td class="tdsm centered">
                    @{
                        if(@thisActive) {
                            <text><input type="checkbox" name="@(thisID + ".active")" value="true" checked="checked" /></text>
                        }
                        else {
                            <text><input type="checkbox" name="@(thisID + ".active")" value="true" /></text>
                        }
                    }
                </td>
            </tr>
        }all of this
    </table>
    <p>
        <input type="submit" value="Update" />
    </p>
</fieldset>
}

控制器:

namespace Library3.Controllers {
    public class ReaderLevelController : Controller {
        private NSSchoolLibraryEntities db = new NSSchoolLibraryEntities();

        public ActionResult Index() {
            ViewBag.Title = "Reader Levels";
            return View(db.PrmTbl_Levels.ToList());
        } 


        [HttpPost, ActionName("Update")]
        [ValidateAntiForgeryToken]
        public ActionResult Update(FormCollection MyArray) {

                (... Process UPDATE submission ...)

                db.SaveChanges();

            }
        }

        return RedirectToAction("Index");

        }
    }
}

现在我想在我的列表顶部放置一个空字段,以便可以创建新条目。这基本上意味着一个视图文件现在将同时满足创建和更新功能。我插入了以下 HTML:

@using (Html.BeginForm("New", "ReaderLevel", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
    @Html.AntiForgeryToken()
    @Html.ValidationSummary(true)

    <fieldset>

        <table>
            <tr>
                <td class="tdsm centered fade">
                    @Html.EditorFor(model => model.LevelID)
                    @Html.ValidationMessageFor(model => model.LevelID)</td>
                <td><input type="text" name="desc" />
                    @Html.EditorFor(model => model.LevelDesc)
                    @Html.ValidationMessageFor(model => model.LevelDesc)</td>
                <td class="tdmed centered fade">
                    @Html.EditorFor(model => model.EnteredBy)
                    @Html.ValidationMessageFor(model => model.EnteredBy)</td>
                <td class="tdsm centered">
                    @Html.EditorFor(model => model.Active)
                    @Html.ValidationMessageFor(model => model.Active)</td>
            </tr>
        </table>
        <p>
            <input type="submit" value="Create" />
        </p>
    </fieldset>
}

...问题是这里引用的模型应该是 PrmTbl_Level 类的新实例 - 不使用现有的 IEnumberable 从表中吐出现有数据(至少这就是我认为问题所在!)。

默认的单独创建视图通过@model(sans IEnumberable) 引用命名空间,并且数据作为单个对象 ( public ActionResult Create(PrmTbl_Level prmtbl_level)) 返回,然后毫不费力地保存到数据库 ( db.PrmTbl_Levels.Add(prmtbl_level);) - 我如何使用一个@model语句实现相同的目标?(ELI5)。所有的帮助——无论是实际的还是所涉及的概念——非常感谢!

4

2 回答 2

2

简而言之,您应该创建一个自定义类,而不是用于您的模型,该类既代表列表(以当前方式显示和编辑),又代表您可以填充以创建新实体/行IEnumerable<Library3.DAL.PrmTbl_Level>的附加项。PrmTbl_Level

所以,像这样:

public class MyCustomModel
{
    public MyCustomModel()
    {
        MyList = new List<PrmTbl_Level>();
        MyItemToCreate = new PrmTbl_Level();
    }

    public List<PrmTbl_Level> MyList { get; set; }
    public PrmTbl_Level MyItemToCreate { get; set; }
}

现在您的强类型模型是 MyCustomModel,您需要更改视图以正确引用新模型(例如model => model.LevelID变为model => model.MyList.LevelID)。

不是一个完整的解决方案,但应该可以帮助您入门。

于 2013-08-23T01:34:10.497 回答
0

在同一列表视图中添加创建视图您可以使用局部视图。并在您的列表视图顶部添加此部分视图,以解决您的问题。创建新条目所需的所有字段都应在部分视图中。

检查这些链接可能会给你一些帮助

检查这些链接可能会给你一些帮助

于 2013-08-23T06:29:22.490 回答