7

在@url.action 上调用部分视图。我正在使用 url.action 显示记录,并希望在用户单击记录时加载部分视图。

这是我的代码,当用户单击它时我想在其上调用部分视图。

<td>
<a href="@Url.Action("Details", new { id=item.TeamId})">
 @Html.DisplayFor(modelItem => item.TeamName)
</a>
</td>

这是我放置部分视图的 Div

<div id="detailsPlace" class="dialog_content3" style="display:none"></div>
         @Html.Partial("_TeamDetails")
    </div>

这是我要渲染的部分视图

@model light.ViewModels.ViewDetailTeam
@{
    var item = Model.Team;
}

    <div class="dialogModal_header">@Html.Label(item.TeamName)</div>
    <div class="dialogModal_content">
        <div class="main-content">
            <div class="navi-but">
                    @Html.Label(item.TeamName)
                </div>
                    @Html.Label(item.Description)
                </div>
            </div>
        </div>

这是我的控制器

public ActionResult Details(int id)
        {

            lightCoreModel.User loggedInUser = new lightCoreModel.User();


                ViewDetailTeam viewDetailTeam = new ViewDetailTeam();
                ViewData["DetailModel"] = viewDetailTeam;
                viewDetailTeam.Retrieve(id);
                return PartialView("_TeamDetails",viewDetailTeam);

        }
now i am facing this problem with pop up its showing me the following screen.

在此处输入图像描述

4

3 回答 3

5

您可以使用 ajax 来获取您的列表详细信息并渲染部分视图而无需刷新整个页面

首先使用命令安装包 jQuery.Ajax.Unobtrusive

安装包 jQuery.Ajax.Unobtrusive

并确保jQuery-xxxx.js 和 jquery.unobtrusive-ajax.js包含在列表之前

修改您的代码,当用户单击它时我想在其上调用部分视图

<a  href="@Url.Action("Details", new { id=item.TeamId})" data-ajax='true' data-ajax-update='#detailsPlace' data-ajax-mode='replace'>

或者

@Ajax.ActionLink("Details", 
                 "Details", 
                  new { id=item.TeamId}, 
                 new AjaxOptions { HttpMethod = "GET", 
                 InsertionMode = InsertionMode.Replace, 
                 UpdateTargetId = "detailsPlace"})

并在您的视图顶部添加此代码

if (Request.IsAjaxRequest())
{
   Layout=null;
}

欲了解更多信息,请访问http://chsakell.com/2013/05/12/mvc-unobtrusive-ajax/

于 2014-11-17T15:32:26.680 回答
5

您将需要 Ajax 来执行此操作。首先,使用以下代码在您的视图中添加一个脚本块:

<script type="text/javascript">
    $(function () {
        $('.details').click(function () {
            var $buttonClicked = $(this);
            var id = $buttonClicked.attr('data-id');

            $.ajax({
                url: '@Url.Action("Details")',
                type: 'GET',
                data: { id: id },
                success: function (partialView) {
                    $('#detailsPlace').html(partialView);
                    $('#detailsPlace').show();
                }
            });
        });
    });
</script>

然后将您的锚标记更改为:

<a href="#" class="details" data-id="@item.TeamId">Details</a>

每当单击具有详细信息类的元素时,都会触发 ajax 调用。单击后,存储在 data-id 属性中的 Id 将传递给控制器​​。当您的控制器将局部视图传回时,局部视图将在 ajax 调用的成功函数中加载,并且会显示 detailsPlace,因为它的显示设置为无。

于 2014-11-17T15:39:29.217 回答
1

如果你想把 PartialView 放在一个 中div,你可能想试试Ajaxhelper。首先,尝试更改ActionResultPartialViewResult. helper的定义之一Ajax如下:

@Ajax.ActionLink("Display name",
        "Your partial action name",
        "Controller name",
        new { /* object values */ }, // e.g. ID = yourmodel.ID or null
            new AjaxOptions {
                HttpMethod = "GET",
                UpdateTargetId = "your div id without #",
                InsertionMode = InsertionMode.Replace
            })
于 2014-11-17T15:38:05.227 回答