我有以下代码由于某种原因无法工作我打算如何工作。基本上我在网上发现了这个例子,并希望根据我的需要调整它,但问题是我似乎无法在页面上显示ImageList。
代码如下: -
<script type="text/javascript">
$(document).ready(function () {
var imageList = $('#imageList');
//hide the imageList initially
imageList.hide();
});
var Project = {
save: function () {
var projectForm = $("#projectForm");
if (projectForm.valid()) {
projectForm.submit();
}
else {
Project.onInvalidForm();
}
},
onInvalidForm: function () {
//CODE FOR INVALID FORM
},
onSaveBegin: function () {
//CODE FOR SAVE BEGIN
},
onSaveSuccess: function () {
//CODE FOR SAVE SUCCESS
$('#imageList').fadeIn('slow');
},
onSaveFailure: function () {
//CODE FOR SAVE FAILURE
},
onSaveComplete: function () {
//CODE FOR SAVE COMPLETE
$('#imageList').fadeIn('slow');
}
};
</script>
@using (Ajax.BeginForm(
"/Create",
new { },
new AjaxOptions
{
InsertionMode = InsertionMode.Replace,
OnComplete = "Project.onSaveComplete",
OnFailure = "Project.onSaveFailure",
OnSuccess = "Project.onSaveSuccess",
OnBegin = "Project.onSaveBegin"
},
new { id = "projectForm", name = "projectForm" }))
{
<div >
我似乎无法指出出现了什么问题,并且无法显示imageList。代码正在通过onSaveSuccess: function ()
和onSaveCompete: function()
,因为我之前在代码中执行了alert('')
来验证它实际上是从那里传递的。
感谢您的帮助和时间
@if(Model != null)
{
@Html.Hidden("hfProjectId", Model.Project.ProjectID)
}
<div class="editor-label">
@Html.LabelFor(m => m.Project.ProjectTitle)
</div>
<div class="editor-field">
@Html.TextBoxFor(m => m.Project.ProjectTitle)
@Html.ValidationMessageFor(m => m.Project.ProjectTitle)
</div>
<div class="editor-label">
@Html.LabelFor(m => m.Project.ProjectText)
</div>
<div class="editor-field">
@Html.TextBoxFor(m => m.Project.ProjectText)
@Html.ValidationMessageFor(m => m.Project.ProjectText)
</div>
<p>
<input type="submit" value="Create" />
</p>
</div>
}
<div id='imageList'>
@{
if (Model != null)
{
if(Model.Project.ProjectID > 0)
{
Html.Partial("~/Views/Shared/ImageUpload.cshtml", new MvcImageUploaderPartial.ViewModels.ImageModel(Model.Project.ProjectID, 2, "Edit"));
}
else
{
Html.Partial("~/Views/Shared/ImageUpload.cshtml", new MvcImageUploaderPartial.ViewModels.ImageModel(0, 0, "Create"));
}
}
}
</div>
** * ** * 更新 * ** * ** * ** * ** * ** * ** * ** * 项目管理员: -
[HttpPost]
public ActionResult Create(Project project)
{
ProjectModel viewModel = new ProjectModel();
if (ModelState.IsValid)
{
db.Projects.Add(project);
db.SaveChanges();
viewModel.Project = project;
return View("Create", viewModel);
}
return View(project);
}
ImageController: -
public ActionResult Index()
{
ImageModel model = new ImageModel();
return RedirectToAction("Create", "Project", model);
}
public ActionResult Save()
{
IEnumerable<Image> ImageList;
//if (!String.IsNullOrEmpty(TempData["ProjectId"].ToString()))
// iProjId = Convert.ToInt32(TempData["ProjectId"]);
foreach (string name in Request.Files)
{
var file = Request.Files[name];
string fileName = System.IO.Path.GetFileName(file.FileName);
Image image = new Image(fileName, Request["description"]);
ImageModel model = new ImageModel();
ImageList = model.Populate();
model.Add(ImageList, image, file);
}
return RedirectToAction("Index", "Image");
}
答案 0 :(得分:0)
我在AjaxOptions
中看到你没有通过UpdateTargetId
。您应该更新以下代码,
@using (Ajax.BeginForm(
"/Create",
new { },
new AjaxOptions
{
UpdateTargetId = "imageList",
InsertionMode = InsertionMode.Replace,
OnComplete = "Project.onSaveComplete",
OnFailure = "Project.onSaveFailure",
OnSuccess = "Project.onSaveSuccess",
OnBegin = "Project.onSaveBegin"
}
//..
另一个重要的事情是,您在UpdateTargetId
中指定的元素应该在主视图中,而不是在ajax操作返回的部分视图中。另外,请确保您引用了不显眼的ajax库。