2

这是我的ajax调用:

  var totalCost = 0;
    function GetTotalCost(start, end, rID) 
    {
        $.ajax({
            url: '@Url.Action("CalculateTotalcost")',
            type: 'POST',
            data: JSON.stringify({ start:start, end:end, rID:rID}),
            dataType: 'json',
            processdata: false,
            contentType: 'application/json; charset=utf-8',
            success: function (data) { totalCost = data; }
//            error: function (xhr, ajaxOptions, thrownError) { $('.datepicker1').datepicker("hide"); },
//            complete: function (x, y) { $('.datepicker1').datepicker("refresh"); }
        });
    }

这是我调用ajax的函数:

 $('.datepicker2').datepicker({
            dateFormat: 'dd/mm/yy',
            firstDay: 1,
            yearRange: '2012:2100',
            beforeShowDay: function (date) {
                var day = date.getDate();
                if (day in alreadyTakenDays) {
                    return [false, '', alreadyTakenDays[day]];
                }
                else return [true, 'IsActive'];
            },
            onChangeMonthYear: function (year, month, inst) {
                alreadyTakenDays = {};
                getEvents(month, year);
            },

            onSelect: function (dateText, inst) {
                var end = dateText.substring(0, 2);
                console.log(end);
                var rID = $('#RoomID').val();
                console.log(rID);
                var startingHole = $('#DateOne').val();
                var start = startingHole.substring(0, 2);
                console.log(start);
                GetTotalCost(start, end, rID);

                document.getElementById('TotalCost').value = totalCost.toFixed(2);

            }
        });

执行 jQuery 脚本后,totalCount总是得到0? 为什么会这样?我该怎么办?我想在 ASP.NET MVC 3 中将 totalCount 指定给 Html.TextBoxFor,这就是我需要 totalCount 的原因。请帮忙。

4

4 回答 4

3

当您在“TotalCost”文本框中设置值时,ajax 调用是异步的并且尚未完成。

于 2012-11-05T20:52:53.433 回答
2

你应该有这样的成功函数处理程序来获得正确的总成本值:

function GetTotalCost(start, end, rID) 
    {
        $.ajax({
            url: '@Url.Action("CalculateTotalcost")',
            type: 'POST',
            data: JSON.stringify({ start:start, end:end, rID:rID}),
            dataType: 'json',
            processdata: false,
            contentType: 'application/json; charset=utf-8',
            success: function (data) { totalCost = data;
                                       document.getElementById('TotalCost').value = totalCost.toFixed(2); 
                                     }
        });
    }

在这样的代码中:

GetTotalCost(start, end, rID); 
document.getElementById('TotalCost').value = totalCost.toFixed(2);

第一行导致 ajax 调用,但它不等待响应,第二行立即执行。稍后,服务器响应后,success执行回调函数。它将在第二行之后执行。这就是您的总值错误的原因 -totalCost在您更新 TotalCost 输入后设置正确的值。

于 2012-11-05T21:00:27.137 回答
1

因为您的帖子是异步的,并且您正在尝试设置一个对页面全局的 js 变量。创建一个设置变量的函数并从回调中调用它,然后您将看到结果。

于 2012-11-05T20:53:26.860 回答
1

那是因为异步ajax请求..

在您处理事件时,请求尚未完成。

欢迎来到 AJAX 的精彩世界。

于 2012-11-05T20:53:37.267 回答