繁体   English   中英

jQuery不调用asp.net MVC中的控制器

[英]JQuery not calling controller in asp.net mvc

我试图使用jquery从视图到控制器进行调用。 但是它永远不会调用控制器。

我在asp.net MVC 4应用程序中有一个Umbraco 7.1.2网站。

我的JS

var dp = jQuery;
dp.noConflict();
dp(document).ready(function() {
    GetTestimonials();
});

function GetTestimonials() {
   dp.ajax({
        type: 'GET',
        url: '/Home/GetTestimonialsList',
        cache: false,
        success: function (data) {
            dp.each(data, function (index, val) {
                alert(val.Name + val.Comment + val.Date);
            });
        },
        error: function () {
            alert("error");
        }
    });
}

然后我的控制器

[HttpGet]
public JsonResult GetTestimonialsList()
{
     var model = _spdb.TestimonialDetails.Where(t => t.Status == Enums.TestimonialsStatus.approved).Select(t => new { t.Comment, t.Name, t.Date});
     return Json(model, JsonRequestBehavior.AllowGet);
}

我在控制器上设置了一个断点,但从未被调用。

在浏览器上,jQuery不会引发任何错误。

但是,它总是触发alert(“ error”); 页面加载时。

我叫console.log(“ test”); 它显示在浏览器调试中。

在同一页面上,我正在使用jquery向控制器发布表单,这完全没有问题。

从数据库查询给我的数据权。

我究竟做错了什么?

非常感谢

好的,找到解决方案。 我将URL更改为url: '/umbraco/surface/home/GetTestimonialsList' ,并且工作正常。

尝试这个。 您正在返回IQuerable。

[HttpGet]
public JsonResult GetTestimonialsList()
{
     var model = _spdb.TestimonialDetails.Where(t => t.Status == Enums.TestimonialsStatus.approved).Select(t => new { t.Comment, t.Name, t.Date}).ToList();
     return Json(model, JsonRequestBehavior.AllowGet);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM