5

我正在尝试使用 Ajax 调用创建一个 MVC 网站。我直接使用 jquery 没有问题,但是当我使用 @Ajax.ActionLink 时,我没有得到我想要的结果。这是我的看法:

    <script type="text/javascript">
        function deleteComment(id) {
            $.post(
                "/Role/AjaxTest",
                //{ id: id }, 

                function (data) {
                    $("#testtarget").html(data);               
                });
         }
    </script>


    <script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
    <h2>TITLE</h2>
    <p>
 @Ajax.ActionLink("Ajax Test", "AjaxTest", "Role", new AjaxOptions{UpdateTargetId="testtarget",HttpMethod = "Get" , InsertionMode = InsertionMode.Replace }) 
    </p>
    <table>    
    @foreach (var item in Model) {
        <tr>
            <td>
                @Html.DisplayFor(modelItem => item.RoleName)
            </td>
            <td>
              <a onclick="deleteComment('@item.RoleId'); return false;" href="#">Delete</a>
                @Html.ActionLink("Delete", "Delete", new { id=item.RoleId })

            </td>
        </tr>
    }
    </table>
    <div id="testtarget">Test Div</div>

这是我的控制器数据:

public string AjaxTest()
{
    return "Some random text";
}

我对 Jquery 的调用完美运行,文本出现在 div 中,但我的操作链接只是将我重定向到:localhost/Role/AjaxTest,所以我只有在银行浏览器中显示消息。

知道这里有什么问题吗?

提前非常感谢!

4

2 回答 2

9

确保您已将jquery.unobtrusive-ajax.js脚本添加到您的页面:

<script type="text/javascript" src="~/scripts/jquery.unobtrusive-ajax.js"></script>

或者如果您正在使用捆绑包(这是推荐的方法),请确保您已包含包含此脚本的捆绑包。例如,当您使用~/bundles/jqueryval捆绑的 Internet 模板创建新的 ASP.NET MVC 4 项目时:

bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
    "~/Scripts/jquery.unobtrusive*",
    "~/Scripts/jquery.validate*")
);

因此,请确保它在 jquery 包之后包含在您的视图中:

@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/jqueryval")

或者只是将它们组合成一个捆绑包。这完全取决于您的要求以及您是否需要不显眼的 jquery 验证支持。

我还建议您让控制器操作返回 ActionResult 而不是字符串:

public ActionResult AjaxTest()
{
    return Content("Some random text");
}
于 2012-10-12T14:39:43.480 回答
2

尝试在浏览器中使用 F12 并检查控制台中是否出现任何脚本错误。Fiddler 还将帮助确定您的任何库是否未正确引用或加载。

于 2012-10-12T22:20:41.970 回答