0

我正在将谷歌地图 v2 项目升级到 v3。到目前为止一切顺利,但我遇到了一个我还没有找到解决方案的问题(尽管我确实有解决方法)。

地图的访问者可以点击一个位置,让纬度和经度出现在信息窗口中,并能够将该数据保存到 XML 文件中。我在 v2 中可以正常工作。

它也适用于 v3,但前提是我删除了所有 Ajax 检查,这似乎很危险。在 v2 中,我有:

        var request = GXmlHttp.create();

// open the request to storeMarker.php on server
request.open('GET', 'storeMarker.php' + getVars, true);
request.onreadystatechange = function() {
    if (request.readyState == 4) {
        // the request is complete
        var xmlDoc = request.responseXML;
        // retrieve the root document element (response)
        var responseNode = xmlDoc.documentElement;
        // retrieve the type attribute of the node
        var type = responseNode.getAttribute("type");

        // retrieve the content ofthe responseNode
        var content = responseNode.firstChild.nodeValue;

        //check to see if it was an error, or success
        if (type != 'success') {
            alert(content);
        } else {
            // create a new marker and add its info window
            var latlng = new GLatLng(parseFloat(lat), parseFloat(lng));
            var marker = makeTempMarker(latlng, content, bus);
            map.addOverlay(marker);
            map.closeInfoWindow();
        }
    }

不知何故,GXmlHttp.create() 似乎已经处理了我称之为“storeMarker.php”而不是 XML 的文件。storeMarker.php 文件确实打开了一个 XML 文件(并成功保存了新标记)。此代码来自“使用 PHP 和 Ajax 开始 Google 地图应用程序”(Apress:Purvis,Sambells & Turner,2006 年),仅适用于 v2。

GXmlHttp.create() 不再适用于 v3,我使用了一个简短的跨浏览器函数来打开 Ajax 请求(此处未复制该函数):

    var request = getAjaxObject();

现在 JS 阻塞在“request.responseXML”上。我已经尝试过“request.responseText”,但是(不出所料)这也不起作用。

我的问题是,我该怎么做?

正如我上面所说的,如果我删除了“status == 200”检查之外的响应检查,并使用适当的 v3 语法,标记数据将被保存并适当地显示一个临时标记。但感觉并不“安全”。

4

1 回答 1

0

我现在发现'storeMarker.php' 文件应该有一个标题'header('Content-Type: text/xml');'。(它在翻译中丢失了)。把它放回去让我进入脚本的下一行(!),但我希望我能从这里解决问题。

于 2013-11-01T09:33:41.260 回答