0

嗨,我有以下 ViewUserControl:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %>

<table>
<tr>
   <td><%= Html.TextBox("") %></td>
   <td><button type="button" id="workType-open-button" class="t-button" onclick="modalWin('http://localhost:29357/WorkType/SelectForTR')">Select</button></td>
</tr>
</table>

<script type="text/javascript">
function modalWin(url) {
    if (window.showModalDialog) {
        window.showModalDialog(url, "Select work type", "dialogWidth:700px;dialogHeight:450px");
    }
    else {
        window.open(url, 'Select work type', 'height=700,width=450,toolbar=no,directories=no,status=no, menubar=no,scrollbars=no,resizable=no ,modal=yes');
    }
} 
</script>

我用它来编辑一个类的下一个属性:

[UIHint("WorkTypes"), Required]
public int WorkType { get; set; }

在 UserControl 我有以下代码:

[HttpPost]
[GridAction]
    public ActionResult InsertTimeRegistration()
    {
        TimeRegistrationViewModel newT = new TimeRegistrationViewModel();

        if (TryUpdateModel(newT))
        {
            //The model is valid - insert the time registration.
            newT.Employee = 6;
            repo.AddTimeRegistration(newT);
        }


        return View(new GridModel(repo.GetAllTimeRegistrationOfAnEmployee(6)));
    }

问题是,如果我从控件中删除按钮,它可以正常工作,但是使用按钮它不会更新模型。POST 的参数在编辑表单中插入了值,但记录没有保存到数据库。

如果可以的话,请给我一个建议。

谢谢

4

1 回答 1

1

这不起作用的原因是您InsertTimeRegistration只能使用 POST HTTP 动词访问。您在 javascript 中调用它的方式是使用其中一个,window.open或者window.showModalDialog我想两者都发送一个 GET 请求(我确定是window.open)。

所以你需要配置你的window.showModalDialog函数来发送一个 POST 请求。这是一个如何<form>使用 AJAX 发布 HTML 的示例:

var formToPost = $('#idofyourform');
$.ajax({
    url: formToPost.attr('action'),
    type: 'POST',
    data: formToPost.serialize(),
    success: function(result) {
        alert('form successfully submitted');
    }
});
于 2011-02-11T07:32:28.537 回答