我在我的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>
嗨约翰尼问题不是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>