我正在将谷歌地图 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 语法,标记数据将被保存并适当地显示一个临时标记。但感觉并不“安全”。