繁体   English   中英

多选下拉项在更新时自动选择属性

[英]Multi select drop-down items auto select attribute on update

在一个页面上,我有一个多选下拉菜单。 每当我需要插入数据时它都可以正常工作,但是当我需要更新插入的数据时会出现问题。

问题每当我单击我的数据旁边的编辑按钮(在我的情况下 - 关于书籍数据)时,表单中的每个字段都会填满,但选择下拉菜单项不会自动选择为以前选择的内容。 我必须再次手动重新选择它。 更新数据本身的过程工作正常(一旦我再次重新选择它)。

它使用多对多关系。 当我使用复选框时工作正常,但我想在下拉菜单上重新执行。

控制器

public ViewResult Index(int? Id)
        {
            SelectList selectList = new SelectList(_authorRepository.GetAllAuthors()
                    .Select(x => new { x.Id, Title = x.Name + " " + x.Lastname }), "Id", "Title");
            BooksIndexViewModel viewModel = new BooksIndexViewModel()
            {
                Books = _booksRepository.GetAllBooks(),
                AuthorOptions = selectList,
                authors = _authorRepository.GetAllAuthors(),
                Book = _booksRepository.GetBook(Id ?? 0),
                publishers = _publisherRepository.GetAllPublishers(),
                indexPage = _dataRepository.Generatedata("Knygos", Id,
                    ControllerContext.RouteData.Values["controller"].ToString())
            };
            return View(viewModel);
        }

AuthorOptions是传递 asp-items 的东西。 表单本身使用Book

Index.cshtml (其他行被删除,只剩下表单)

<form asp-controller="@Model.indexPage.controller" 
    asp-action="@Model.indexPage.action" 
    asp-route-id="@if (Model.indexPage.routeId.HasValue) {@Model.indexPage.routeId.Value}"  method="post">
        <div class="inputs">
            <div> <input asp-for="@Model.Book.Title" /> </div>
            <div> <select asp-for="@Model.Book.BookAuthors" 
                asp-items="@Model.AuthorOptions" name="author[]"></select> </div>
            <div>
                <select asp-for="@Model.Book.PublisherId"  
                    asp-items="@(new SelectList(Model.publishers, "Id", "Title"))"></select>
            </div>
            <div><input asp-for="@Model.Book.Cost" /></div>
            <div><input asp-for="@Model.Book.Code" /></div>
            <div><input asp-for="@Model.Book.InvNr" /></div>
            <div><input asp-for="@Model.Book.Description" /></div>
        </div>
        <button type="submit">Save</button>
    </form>

我之后的行是<select asp-for="@Model.Book.BookAuthors" asp-items="@Model.AuthorOptions" name="author[]"></select> 它和整个表单从我的存储库中获取数据。

存储库

public Book GetBook(int Id)
        {
            return db.Books.Include(x => x.BookAuthors).SingleOrDefault(x => x.Id == Id);
        }

下拉列表中的ValueAuthorIdBook模型中的BookAuthors是一个IList并连接到BookAuthor模型:

public class BookAuthor
    {
        public int BookId { get; set; }
        public Book Book { get; set; }
        public int AuthorId { get; set; }
        public Author Author { get; set; }
    }

所以问题是,为什么每当我从我的 Id 获取图书数据时,所有字段(包括PublisherID是一个下拉列表但单对单连接)都会被选中,但我的 Authors 下拉列表没有? 我错过了什么?

编辑 1

通过更改asp-for="@Model.Book.BookAuthors" => asp-for="@Model.Book.BookAuthors[0].AuthorId"如果书籍数据超过 1,则可以通过更改来获得选择。作者,仅从下拉菜单中选择了 1 个作者。 + 下拉菜单不再是多选的,但可以通过添加multiple属性来覆盖,但仍只能从下拉菜单中选择 1 个项目。

想了个妙招。

在 viewModel 中创建了一个 IList 整数public IList<int> AuthorIds 在 .cshtml 中, int asp-for=""使用了新创建的整数列表AuthorIds 在控制器内部,ViewModel 中的AuthorIds通过_booksRepository.GetBook(Id).BookAuthors.Select(x => x.AuthorId).ToList();

所以项目看起来是这样的:

控制器

public ViewResult Index(int? Id)
        {
            BooksIndexViewModel viewModel = new BooksIndexViewModel()
            {
                Books = _booksRepository.GetAllBooks(),
                AuthorOptions = new SelectList(_authorRepository.GetAllAuthors()
                    .Select(x => new { x.Id, Title = x.Name + " " + x.Lastname }), "Id", "Title"),
                Book = _booksRepository.GetBook(Id),
                publishers = _publisherRepository.GetAllPublishers(),
                indexPage = _dataRepository.Generatedata("Knygos", Id,
                    ControllerContext.RouteData.Values["controller"].ToString())
            };
            if (Id != null)
                viewModel.AuthorIds = _booksRepository.GetBook(Id).BookAuthors.Select(x => x.AuthorId).ToList();
            return View(viewModel);
        }

cshtml

<form asp-controller="@Model.indexPage.controller" asp-action="@Model.indexPage.action"
          asp-route-id="@if (Model.indexPage.routeId.HasValue) {@Model.indexPage.routeId.Value}" 
          method="post" class="form grid">
        <div class="inputs">
            <div><input asp-for="@Model.Book.Title" class="w100" /></div>
            <div><select asp-for="@Model.AuthorIds" asp-items="@Model.AuthorOptions"
                name="author[]" multiple></select></div>
            <div><select asp-for="@Model.Book.PublisherId" 
                        asp-items="@(new SelectList(Model.publishers, "Id", "Title"))">
            </select></div>
            <div><input asp-for="@Model.Book.Cost" /></div>
            <div><input asp-for="@Model.Book.Code" /></div>
            <div><input asp-for="@Model.Book.InvNr" /></div>
            <div><input asp-for="@Model.Book.Description" /></div>
        </div>
        <button type="submit">Save</button>
    </form>

其他一切都没有改变。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM