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);
        } 

文档操作结果可以获取模型,但我想知道如何从将触发 PreviewWordDocument 操作的操作链接中获取值。

提前致谢, Laziale

4

2 回答 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>

干杯!

于 2012-12-06T20:32:09.130 回答
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);
} 
于 2012-12-06T20:43:15.877 回答