更新发送到控制器查看的数据

时间:2015-09-22 22:14:45

标签: javascript asp.net-mvc

我正在使用Google Maps API制作地图,该地图将显示服务器上玩家的当前位置。该列表由游戏服务器更新,数据存储在Web应用程序所在的MySql数据库中。当用户打开地图时,玩家列表及其位置将从数据库中提取并发送到View

public ActionResult Index()
{
    return View(loadData()); //List<MapModel>
}

在视图上我为每个玩家在各自的位置创建一个标记。我有一个计时器,可以创建/更新/删除标记(我已经删除了此演示的不必要代码)

setInterval("updateMap();", 1000);
function updateMap()
{
    **<update data somehow>**
    @foreach(var player in Model)
    {
        <text>
        players[@player.playerid] = new google.maps.Marker({
            position: SanMap.getLatLngFromPos(@player.pos_x, @player.pos_y),
            map: map
        });
        </text>
    }
}

问题是如何更新数据?

1 个答案:

答案 0 :(得分:1)

尝试这样的事情。

 public JsonResult GetPlayers()
    {
        return Json(loadData()); //List<MapModel>
    }

然后在javascript中使用jquery post方法

 function updateMap()
    {

$.post('/SomeController/GetPlayers', function(data){

    for(var i =0; i<data.length; i++)
    {

        players[data[i].playerid] = new google.maps.Marker({
            position: SanMap.getLatLngFromPos(data[i].pos_x, data[i].pos_y),
            map: map
        });

    }
});

}