javascript - AJAX、JavaScript、ASP.Net MVC 问题

标签 javascript asp.net-mvc ajax

大家好!

  • 我正在编写 Asp.Net MVC 2 网站。
  • 我有 TimeController 和 TimeView,CountDownHelper 用于 TimeView 页面上的渲染时间。
  • 我还有用于更新当前时间的 JavaScript,用于 CountDownHelper。

我需要从此 JavaScript 调用 AJAX 以获取服务器上的当前时间。 我该怎么做?请帮我!我必须完成大约几个小时!

您可能会在下面看到这个 javaScript,最后我尝试调用 AJAX。我曾尝试以多种方式编写 GetServerTime.html,但任何人都无法使用。 (((

 //countDown.js  
function calcage(secs, num1, num2) 
{
    s = ((Math.floor(secs / num1)) % num2).toString();
    if (LeadingZero && s.length < 2)
        s = "0" + s;
    return "<b>" + s + "</b>";
}

function CountBack(secs) 
{
    if (secs < 0) 
    {
        location.reload(true);
        document.getElementById("cntdwn").innerHTML = FinishMessage;
        return;
    }

    //difference between recieve time and current client time
    diff = new Date(new Date() - clientTime);
    targetD = new Date(TargetDate);
    serverD = new Date(serverDate);
    currentServerDate = new Date(serverD.getTime() + diff.getTime());

//targetD
    leftD = new Date(targetD.getTime() - currentServerDate.getTime());

    secs = leftD.getTime() / 1000;

    DisplayStr = DisplayFormat.replace(/%%D%%/g, calcage(secs, 86400, 100000));
    DisplayStr = DisplayStr.replace(/%%H%%/g, calcage(secs, 3600, 24));
    DisplayStr = DisplayStr.replace(/%%M%%/g, calcage(secs, 60, 60));
    DisplayStr = DisplayStr.replace(/%%S%%/g, calcage(secs, 1, 60));

    document.getElementById("cntdwn").innerHTML = DisplayStr;
    if (CountActive)
        setTimeout("CountBack(" + (secs + CountStepper) + ")", SetTimeOutPeriod);
}

function putspan(backcolor, forecolor) 
{
    document.write("<span id='cntdwn' style='background-color:" + backcolor +
                "; color:" + forecolor + "'></span>");
}

if (typeof (BackColor) == "undefined")
    BackColor = "white";
if (typeof (ForeColor) == "undefined")
    ForeColor = "black";
if (typeof (TargetDate) == "undefined")
    TargetDate = "12/31/2020 5:00 AM";
if (typeof (serverDate) == "undefined")
    serverDate = "12/31/2020 5:00 AM";
if (typeof (DisplayFormat) == "undefined")
    DisplayFormat = "%%D%% Days, %%H%% Hours, %%M%% Minutes, %%S%% Seconds.";
if (typeof (CountActive) == "undefined")
    CountActive = true;
if (typeof (FinishMessage) == "undefined")
    FinishMessage = "";
if (typeof (CountStepper) != "number")
    CountStepper = -1;
if (typeof (LeadingZero) == "undefined")
    LeadingZero = true;


CountStepper = Math.ceil(CountStepper);
if (CountStepper == 0)
    CountActive = false;
var SetTimeOutPeriod = (Math.abs(CountStepper) - 1) * 1000 + 990;
putspan(BackColor, ForeColor);
var dthen = new Date(TargetDate);
var dtServ = new Date(serverDate);
var dnow = new Date();
if (CountStepper > 0)
    ddiff = new Date(dnow - dthen);
else
    ddiff = new Date(dthen - dtServ);
    //ddiff = new Date(TargetDate - serverDate);
//ddiff = new Date(dthen - dnow);
gsecs = Math.floor(ddiff.valueOf() / 1000);
CountBack(gsecs);

alert("Start");
alert(serverDate);

//AJAX CALL ???? 
//How to call async JavaScript?
//Which must be GetServerTime.html

$.get('Views/GetServerTime.html', function(data) {
    serverDate = data;
    clientTime = new Date();    
});

alert(serverDate);**

最佳答案

通常您不会直接访问您的 View 。 View 通常是一个 .ASPX 文件。

所以

$.get('Views/GetServerTime.html',...

成为

$.get('/GetServerTime/',...

对于 Views/GetServerTime/Index.aspx View 和 getserverTimeController.cs Controller ,默认操作为 Index

但我猜这不是您遇到的唯一问题?...

编辑

此外,您可能应该为此使用 JSON。您可以使用 System.Web.Mvc.JsonResult自动将您的结果作为 JSON 发送,jQuery 将处理此 JSON 并将其转换为 javascript 对象。

        $.get('/GetServerTime/', 
                        function (data)
                        {
                                if (data.HasError == false)
                                {
                                    $("#resultDiv").html(data.ServerTime);
                                }
                        }, "json");

您的 MVC 操作可能如下所示...

public JsonResult Index(string id)
{
    JsonResult res = new JsonResult();          
    res.JsonRequestBehavior = JsonRequestBehavior.AllowGet;

    res.Data = new { ServerTime = DateTime.Now(), HasError = false };

    return res;
}

以上是近似值,因为我没有编译器。

关于javascript - AJAX、JavaScript、ASP.Net MVC 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3851638/

相关文章:

asp.net-mvc - X-SourceFiles header 有什么作用?

javascript - 在加载所有 ajax 调用后如何调用函数?

php - AJAX/JQUERY 不更新 MySQL 行

javascript - 从 Windows 8 Store 应用本地存储中提取数据

asp.net-mvc - Url.Action 从 Route 属性映射错误的链接

javascript - 如何创建一个字符串并使用以它命名的函数?

asp.net - 如何衡量 ASP.NET MVC ActionLink 的成功?

php - 从 PHP 中的 Ajax POST 请求获取数据?

javascript - 使用复选框选择要从 JavaScript 中选择随机值的数组

javascript - 确定 .always 函数中 ajax 调用是否失败