JQuery 不会将任何内容传递给 ASP.NET Controller

标签 jquery ajax json asp.net-mvc-4 parameter-passing

我已经使用了大约两天,搜索和尝试。但我仍然无法实现我的目标:

将 Jquery 对话框 slider 值传递给 Controller ​​。

前端:

@model TheMoodApp.Models.tbl_user
@{
    ViewBag.Title = "ControlPanel";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

<h2>@Html.DisplayFor(u=>u.Forename)'s Control Panel</h2>
@* Adding header stuff for control panel *@
@section DialogControlPanel{
    <link rel="stylesheet" href="http://code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css" />
    <script src="http://code.jquery.com/jquery-1.8.3.js"/>
    <script src="https://raw.github.com/brandonaaron/bgiframe/master/jquery.bgiframe.js"/>
    <script src="http://code.jquery.com/ui/1.9.2/jquery-ui.js"/>
    <script src="~/Scripts/MoodAppScripts.js"/>
    <link href="~/Content/MoodApp.css" rel="stylesheet" />
}
@*The dialog for set initial mood*@
<div id="dialog-modal" title="Hi @Html.DisplayFor(u=>u.Forename)<br/>How do U feel 2Day?">
    <header id="InitialMoodHeader">
        <p>Set UR Mood 
            <input type="text" id="DisplayMood" readonly="readonly"/>
        </p>
    </header>
    <section id="InitialMoodSlider">
        <div id="MoodSlider"></div>
    </section>
</div>

Javascript文件:

$(document).ready(

function () {
    $("#dialog-modal").dialog({
        height: 140,
        modal: true,
        buttons: {
            "This is my Mood": function () {
                $.ajax({
                    url: '@Url.Action("User", "CheckInMood")',
                    data: JSON.stringify({ mood: $("#DisplayMood").val() }),
                    type: 'POST',
                    contentType: 'application/json; charset=utf-8',
                });
                $(this).dialog("close");
            }
        }

    });

    $("#MoodSlider").slider({
        //TODO: IMPLEMENT JSON TO GET MOOD; ATM FEATURE IS FIXED.
        range: "max",
        min: 0,//scales minimum
        max: 3,//scales maximum
        value: 2,//default value
        slide: function (event, ui) {
            $("#DisplayMood").val(ui.value);//get value from slider and display it
        } 
    });
    $("#DisplayMood").val(
        $("#MoodSlider").slider("value")
        );//set input value from slider
});

Controller :

[HttpPost]
    public JsonResult CheckInMood(string mood)
    {
        //current user checks in with current mood
        uint i = Convert.ToUInt16(mood);
        return Json(View());
    }

有人可以帮助我,让它发挥作用,并向我解释我做错了什么吗?

提前致谢

//硼

最佳答案

看来您在 JavaScript 文件中包含了 Razor 代码:@Url.Action("User", "CheckInMood")

由于这是一个 javascript 文件,因此 Razor 将不会用于呈现该值,因此会将其视为文字。

您需要做的是将 URL 从 View 传递到 JavaScript。

关于JQuery 不会将任何内容传递给 ASP.NET Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13850649/

相关文章:

javascript - 如何在 JSON.stringify 中传递 JQuery 变量并在服务器端接收?

javascript - jQuery 下一个循环不会回到第一个 child

jquery PageMethod 说该方法不存在

javascript - 在提交远程引导模态 Rails 表单之前触发 js

java - 与 Jackson 映射时将默认值设置为空字段

java - 通用 JSON 对象转换

jquery - 如何消除标题和导航栏之间的差距?

javascript - 如何删除 mouseleave 上 append 的工具栏到主体或其他元素?

php - 为什么这个ajax脚本不使用ajaxRequest.open调用后端php?

java - 将 Jackson Mixins 与 MappingJacksonHttpMessageConverter 和 Spring MVC 结合使用