刷新部分视图后,Ajax重新加载页面

问题描述 投票:0回答:1

我在我的Index.cshtml中有一个局部视图,并在我的局部视图中有一个列表。当我单击列表项时,它调用selectProj()并通过ajax作为Test进行警报。这就是我需要的。我的问题是我的列表中有一个按钮作为添加新项目。当我添加项目时,我重新加载局部视图。重新加载局部视图后,当我单击列表项时,它会再次发出警报但刷新index.cshtml但刷新页面后它只会提醒不刷新。我不想刷新我的索引。我会问你关于如何避免提神的意见。非常感谢你的回答!

我在下面的Index.cshtml中的代码块;

<div id="projectListDiv">
      @Html.Partial("SelectProjectListPartialView", @Model)
</div>

我的部分视图就是这样......

@model Projact.Models.ViewModels.IndexViewModel

<div>
   <button id="collapsibleProjectBtn" class="collapsible">Select Project</button>
   <div class="content">
        <ul id="projectList">
        @{
           if (Model != null)
           {
             foreach (var project in Model.Projects)
                {
                    <li id="[email protected]"><a href="" onclick="selectProj(@project.Id, '@project.ProjectName.ToString()')">@project.ProjectName</a></li>
                }
            }
          }
          <li><button type="button">Add new project</button></li>
        </ul>
   </div>
</div>

<script type="text/javascript">

    var selectProj = function (projectId, projectName) {

        $.ajax({
            url: '@Url.Action("GetDocuments","Home")',
            contentType: "application/json; charset=utf-8",
            data: { 'projectId': projectId},
            type: 'GET',
            cache: 'false',
            dataType: 'json',
            success: function (result) {                
                alert("Test");
            }
        });        
    }
</script>
asp.net ajax asp.net-mvc partial-views
1个回答
0
投票

嗨约翰尼问题不是ajax调用,而是触发ajax的链接,我的意思是因为你的代码没有阻止它导航的链接的默认行为;这就是为什么它似乎刷新页面。

你能试一下吗?

<a href="" onclick="selectProj(event, @project.Id, '@project.ProjectName.ToString()')">

<script type="text/javascript">

    var selectProj = function (e, projectId, projectName) {
        e.preventDefault();

        $.ajax({
            url: '@Url.Action("GetDocuments","Home")',
            contentType: "application/json; charset=utf-8",
            data: { 'projectId': projectId},
            type: 'GET',
            cache: 'false',
            dataType: 'json',
            success: function (result) {                
                alert("Test");
            }
        });

    }
</script>
© www.soinside.com 2019 - 2024. All rights reserved.