使用html.actionlink将模型从视图传递到控制器

7

我正在尝试从强类型视图中获取模型数据到控制器。使用提交按钮可以正常工作,我可以获取数据。现在我想用html.actionlink实现相同的功能。这是我的代码:

视图:
@model WordAutomation.Models.Document    
    @{
        ViewBag.Title = "Document";
    }
      <script type="text/javascript">
          $(function () {
              $("#dialog").dialog();
          });
        </script>

    <h2>Document</h2>

    @using (Html.BeginForm()) {
        @Html.ValidationSummary(true)

        <fieldset>
            <legend>Document</legend>

            <div class="editor-label">
                @Html.LabelFor(model => model.ClientTitle)
            </div>
            <div class="editor-field">
                @Html.EditorFor(model => model.ClientTitle)
                @Html.ValidationMessageFor(model => model.ClientTitle)
            </div>

            <div class="editor-label">
                @Html.LabelFor(model => model.ClientFullName)
            </div>
            <div class="editor-field">
                @Html.EditorFor(model => model.ClientFullName)
                @Html.ValidationMessageFor(model => model.ClientFullName)
            </div>

            <div class="editor-label">
                @Html.LabelFor(model => model.ClientCustomSSN)
            </div>
            <div class="editor-field">
                @Html.EditorFor(model => model.ClientCustomSSN)
                @Html.ValidationMessageFor(model => model.ClientCustomSSN)
            </div>

            <p>
                <input type="submit" value="Create" />            
            </p>
        </fieldset>
    }

    <div>
        @Html.ActionLink("Preview", "PreviewWordDocument", "Home", null, new { id = "previewLink" })    

    </div>

    <div id="dialogcontainer">
        <div id="dialogcontent"><input type="submit" value="Create" />        </div>
    </div>

    @section Scripts {

        <script type="text/javascript">

                $(document).ready(function() {

                    $("#dialogcontainer").dialog({
                        width: 400,
                        autoOpen:false,
                        resizable: false,
                        title: 'Test dialog',
                        open: function (event, ui) {
                            $("#dialogcontent").load("@Url.Action("PreviewWordDocument", "Home")");
                        },
                        buttons: {
                            "Close": function () {
                                $(this).dialog("close");
                            }
                        }
                    });

                    $("#previewLink").click(function(e) {
                        e.preventDefault();
                        $("#dialogcontainer").dialog('open');
                    });

                });

            </script>
    }

控制器:

public ActionResult Document()
        {      
            return View();
        }

        [HttpPost]
        public ActionResult Document(WordAutomation.Models.Document model)
        {
            Models.Utility.EditWord word = new Models.Utility.EditWord();
            word.EditWordDoc(model);
            return View("Display", model);
        }

        public ActionResult PreviewWordDocument()
        {           
            var image = Url.Content("~/Content/preview.jpeg");

            return PartialView((object)image);
        } 

文档的actionresult可以获取模型,但我想知道如何从触发PreviewWordDocument操作的actionlink中获取值。

提前感谢,Laziale

2个回答

5
在HTML页面中,当您单击提交按钮时,该按钮所在表单内的所有输入元素都将被发送到服务器。但是,如果您单击锚标签(<a>),则仅使用Get方法发送请求且不会发布任何值。但是,如果您想使用此方法向服务器发送特定值,则可以通过查询字符串实现。您已经使用以下内容进行请求:
     @Html.ActionLink("Preview", "PreviewWordDocument", "Home", null, 
     new { id = "previewLink" })

这将产生以下结果:
<a id="previewLink" href="/Home/PreviewWordDocument"> Preview </a>

以下是正确的做法。使用ActionLink时,需要使用第四个参数来向服务器传递任何值:

     @Html.ActionLink("Preview", "PreviewWordDocument", "Home",
     new { id = "previewLink" }, null)

这段代码的结果将是:
 <a href="/Home/PreviewWordDocument?id=previewLink"> Preview </a>

干杯!


5
表单只能使用提交按钮提交到其action属性指定的URL。
但是,您可以使用jQuery post方法将表单数据手动验证后发送到不同的URL。 这样,您可以将表单数据发送到PreviewWordDocument控制器方法,并处理响应以在所需的div中显示预览。 (如果给表单分配一个id,使用jQuery就可以轻松找到它)
因此,您的预览链接的点击事件处理程序将如下所示:
$("#previewLink").click(function(e) {
    e.preventDefault();
    if($("#YourFormId").valid()){
        $("#dialogcontainer").dialog('open');
    }
});

在对话框的打开函数中,您将使用jQuery ajax函数将已验证的表单提交到预览控制器方法。响应将加载到dialogContent div中。
    $.ajax({
        type: "POST",
        url: $("#previewLink").attr("href"), //the preview controller method
        data: $("#YourFormId").serialize(), 
        success: function (data) {
            //load ajax response into the dialogContent div
            $("#dialogcontent").html(data);
        },
        error: function(xhr, error) {
            $("#YourFormId").prepend('<div id="ajaxErrors"></div>')
                            .html(xhr.responseText);
        }
    });

现在您将能够在PreviewWordDocument操作中获得整个文档。
public ActionResult PreviewWordDocument(WordAutomation.Models.Document model)
{           
    var image = Url.Content("~/Content/preview.jpeg");

    return PartialView((object)image);
} 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接