0

我的javascript代码有问题。我正在使用谷歌地图,我正在从服务器以 json 格式收集数据。当我在某些浏览器的控制台窗口中检查数据时,我可以看到数据实际上正在到来。

我的问题是变量被读取一次,我在文本框中显示它的值。现在,当我不断接收数据时,变量总是相同的,知道为什么吗?而且我 100% 确信我得到了不同的价值观。

这是代码:

function updateTrucks() {
    $.ajax({
        url: "get_data.php",
        cache: false,
        dataType: 'json',
        data: {},
        error: function(jqxhr, textStatus, errorThrown) {
            alert("Error: " + textStatus + " " + errorThrown);
        },
        success: function(data) {
        for(var i = 0; i < data.results.length; i++) {
            if(trucks.hasOwnProperty(data.results[i].id)) {
                // update position
                trucks[data.results[i].id].setPosition(new google.maps.LatLng(
                parseFloat(data.results[i].lat),
                parseFloat(data.results[i].lng)));
                trucks[data.results[i].id].speed = data.results[i].speed;
            }
            else {
                // code
            }

            google.maps.event.addListener(trucks[data.results[i].id], 'position_changed', function() {
                if(typeof tracked !== "undefined") {
                    if(this.id == tracked.id) {
                        map.panTo(this.getPosition());
                        $("#speed").val(this.speed);
                    }
                }
            });     

此行无法正常工作$("#speed").val(this.speed);

4

2 回答 2

0

我认为您需要在更新位置时更改命令的顺序,因此当 position_changed 触发时,速度属性将被刷新:

if(trucks.hasOwnProperty(data.results[i].id)) {
                trucks[data.results[i].id].speed = data.results[i].speed;
                // update position
                trucks[data.results[i].id].setPosition(new google.maps.LatLng(
                  parseFloat(data.results[i].lat),
                  parseFloat(data.results[i].lng)));
              }
于 2012-06-17T08:56:12.017 回答
0

在javascript中你可以做

document.getElementById("clicks").innerHTML = stuff;

在javascript中调用var stuff,在html中调用varclicks

于 2017-04-17T16:17:24.630 回答