我是MVC的新手,所以请原谅我,如果我是这样的菜鸟:)。
在我的新项目中,我想创建一个“创建歌曲”页面,当然,它会创建一首新歌。在模特设计中,一首歌可以有很多艺术家。因此,在创建歌曲页面上,用户应该能够搜索艺术家并通过在搜索结果中按艺术家的“添加”链接来添加搜索结果中的艺术家。
目前,我在表单中有两个提交按钮,分别是“提交”和“搜索艺术家”,他们调用http POST“创建”动作方法。 ViewModel对象(CreateSongScrnData
)用于发布屏幕数据。而且一切正常。但是当我尝试从Artist搜索结果添加艺术家时,使用@Url.Action
将ViewModel数据传递给“Create”http get方法,当viewmodel对象参数进入actiona方法时,它始终为null。如果我遗漏了一些概念,请帮我提一些建议并启发我。非常感谢你。
代码如下。
public ActionResult Create(CreateSongScrnData modelData, Int32? artistIDToAdd)
{
if (modelData != null && artistIDToAdd != null)
{
var artist = db.Artists.Find(artistIDToAdd);
modelData.Song.Artists.Add(artist);
}
ViewBag.GenreID = new SelectList(db.Genres, "GenreID", "Name");
ViewBag.AlbumID = new SelectList(db.Albums, "AlbumID", "Name");
return View(modelData);
}
[HttpPost]
public ActionResult Create(CreateSongScrnData modelData)
{
switch (modelData.SubmitCommand)
{
case "AddNewSong":
if (ModelState.IsValid)
{
db.Songs.Add(modelData.Song);
db.SaveChanges();
return RedirectToAction("Index");
}
break;
default:
modelData.SearchResult = db.Artists.Where(a => a.Name.Contains(modelData.ArtistSearchString)).ToList();
break;
}
ViewBag.GenreID = new SelectList(db.Genres, "GenreID", "Name", modelData.Song.GenreID);
ViewBag.AlbumID = new SelectList(db.Albums, "AlbumID", "Name", modelData.Song.AlbumID);
return View(modelData);
}
视图中的搜索代码段如下:
<h2>Create</h2>
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<div class="editor-label">
@Html.LabelFor(model => model.Song.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Song.Name)
@Html.ValidationMessageFor(model => model.Song.Name)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Song.MyanmarName)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Song.MyanmarName)
@Html.ValidationMessageFor(model => model.Song.MyanmarName)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Song.Genre)
</div>
<div>
@Html.DropDownList("GenreID", "Choose Genre")
@Html.ValidationMessageFor(model => model.Song.GenreID)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Song.AlbumID, "Album")
</div>
<div class="editor-field">
@Html.DropDownList("AlbumID", "Choose Album")
@Html.ValidationMessageFor(model => model.Song.AlbumID)
</div>
<div class="editor-label">
<p>Sing by this artists:</p>
@if (Model.AddedArtists != null)
{
<table><tr><th>Name</th></tr>
@foreach (var item in Model.AddedArtists)
{
<tr><td>@item.Name</td></tr>
}
</table>
}
</div>
<div style=" border-top:1px solid #ccc; width: 400px; height:auto; margin-top:30px; margin-bottom:30px;"></div>
<div>
<p>Search and add artists</p>
@Html.TextBoxFor(model => model.ArtistSearchString)
<input type="submit" name="SubmitCommand" value="SearchArtist" class="cancel" />
@if (Model.SearchResult != null)
{
<div>
<table><tr><th>Name</th><th></th></tr>
@foreach (var item in Model.SearchResult)
{
<tr><td>@item.Name</td>
<td><a href="@Url.Action("Create", "Song", new { modelData = Model })">Add</a></td>
</tr>
}
</table>
</div>
}
</div>
<div style=" border-top:1px solid #ccc; width: 400px; height:auto; margin-top:30px; margin-bottom:30px;"></div>
<p>
<input type="submit" name="SubmitCommand" value="AddNewSong" />
</p>
}
答案 0 :(得分:0)
我认为你在一个单一的形式混合东西。
解决方案1)
创建用户插入数据和创建歌曲的第一步。
创建第二步,用户将歌手添加到歌曲中。
解决方案2)
让提交按钮存储数据的功能。
为了搜索艺术家,请使用这样的ajax组件: