使用jQuery在MVC中的DisplayFor和EditorFor之间切换

时间:2014-07-25 06:39:10

标签: jquery asp.net-mvc

必须有一种方法可以在我的View上切换DisplayFor和EditorFor div。我想点击"编辑"显示字段旁边的按钮,隐藏DisplayFor元素,并显示EditorFor字段。完成文本更新后,我想在“编辑器”字段中提交表单和数据。

我不确定为什么这不起作用,提示?

我的jQuery

<script type="text/javascript">

function myFunction(element) {

    $(element).find("span.item-display").html($(element).find("span.item-field").find(":input:first").val());
    $(element).find("span.item-display")
        .show()
        .next("span.item-field")
        .hide();
}

我的HTML视图

<dt><strong>@Html.LabelFor(m => m.FirstName) </strong></dt>
        <dd>
            <span class="item-display">
                @Html.DisplayFor(m => m.FirstName)
            </span>
            <span class="item-field" style="display:none">
                @Html.EditorFor(m => m.FirstName)
            </span>

            <span>
                <button type="button" onclick="myFunction(this)" />

            </span>
        </dd>

1 个答案:

答案 0 :(得分:5)

使用 Jquery切换,如下所示:

<dt><strong>@Html.LabelFor(m => m.FirstName) </strong></dt>
    <dd>
        <span class="item-display toggle-control">
            @Html.DisplayFor(m => m.FirstName)
        </span>
        <span class="item-field toggle-control" style="display:none">
            @Html.EditorFor(m => m.FirstName)
        </span>

        <span>
            <button type="button" onclick="toggler()" />

        </span>
    </dd>
  </dt>

<script>
function toggler()
{
    $(".toggle-control").toggle();
}
</script>