Google 地图 API V3 Z-index 不工作
Google Maps API V3 Z-index Not Working
我有一张地图,上面有大约 20 个标记,代表祖先的出生地。标记是从 XML 创建的。我希望后代在前,前代在后,但是 Google 地图默认为最南端的标记在前。代码的最简单形式如下所示:
<!DOCTYPE html >
<head>
<link rel="stylesheet" href="css/style.css" type="text/css">
<script src="https://maps.googleapis.com/maps/api/js?key=MYKEY" type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
var map = null;
var thisLatLng = {lat: 51, lng: -3.5};
function load() {
var map = new google.maps.Map(document.getElementById("map"), {
center: thisLatLng,
zoom: 9,
mapTypeId: 'roadmap'
});
// Change this depending on the name of your PHP file
downloadUrl("php-to-xml.php", function(data) {
var xml = data.responseXML;
var markers = xml.documentElement.getElementsByTagName("marker");
for (var i = 0; i < markers.length; i++) {
var name = markers[i].getAttribute("person");
var gender = markers[i].getAttribute("gender");
var z_index = markers[i].getAttribute("z_index");
var lat = parseFloat(markers[i].getAttribute("lat"));
var lng = parseFloat(markers[i].getAttribute("lng"));
var point = new google.maps.LatLng(lat,lng);
var comment = markers[i].getAttribute("comment");
var colour = markers[i].getAttribute("colour");
var html = "<b>" + name + "</b> <br/>" + comment;
var icon = "images/" + gender + "_" + colour + ".png";
var marker = new google.maps.Marker({
map: map,
position: point,
icon: icon,
optimized: false,
zIndex: z_index
});
}
});
}
function downloadUrl(url, callback) {
var request = window.ActiveXObject ?
new ActiveXObject('Microsoft.XMLHTTP') :
new XMLHttpRequest;
request.onreadystatechange = function() {
if (request.readyState == 4) {
request.onreadystatechange = doNothing;
callback(request, request.status);
}
};
request.open('GET', url, true);
request.send(null);
}
function doNothing() {}
//]]>
</script>
</head>
<body onload="load()">
<div id="map"></div>
</body>
</html>
z-index 的值从 100 到 200 不等,增量为 10,具体取决于代数。不过,我也试过将它们设为 9100 到 9200,以及其他各种东西。
我看到有人建议图标需要 CSS "position" 才能使 z-index 正常工作。不过我试过了
#map img[src^='/myfamilyroots/images'] {position:relative!important;}
以及该主题的许多变体都没有成功。
这让我发疯。据我所知,我已遵循 Google 地图参考指南,但我所做的任何事情都不会改变标记的显示方式。
zIndex
应为数字类型,但 getAttribute()
总是 returns 字符串。
在分配 zIndex 之前将字符串转换为数字
var z_index = Number(markers[i].getAttribute("z_index"));
我有一张地图,上面有大约 20 个标记,代表祖先的出生地。标记是从 XML 创建的。我希望后代在前,前代在后,但是 Google 地图默认为最南端的标记在前。代码的最简单形式如下所示:
<!DOCTYPE html >
<head>
<link rel="stylesheet" href="css/style.css" type="text/css">
<script src="https://maps.googleapis.com/maps/api/js?key=MYKEY" type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
var map = null;
var thisLatLng = {lat: 51, lng: -3.5};
function load() {
var map = new google.maps.Map(document.getElementById("map"), {
center: thisLatLng,
zoom: 9,
mapTypeId: 'roadmap'
});
// Change this depending on the name of your PHP file
downloadUrl("php-to-xml.php", function(data) {
var xml = data.responseXML;
var markers = xml.documentElement.getElementsByTagName("marker");
for (var i = 0; i < markers.length; i++) {
var name = markers[i].getAttribute("person");
var gender = markers[i].getAttribute("gender");
var z_index = markers[i].getAttribute("z_index");
var lat = parseFloat(markers[i].getAttribute("lat"));
var lng = parseFloat(markers[i].getAttribute("lng"));
var point = new google.maps.LatLng(lat,lng);
var comment = markers[i].getAttribute("comment");
var colour = markers[i].getAttribute("colour");
var html = "<b>" + name + "</b> <br/>" + comment;
var icon = "images/" + gender + "_" + colour + ".png";
var marker = new google.maps.Marker({
map: map,
position: point,
icon: icon,
optimized: false,
zIndex: z_index
});
}
});
}
function downloadUrl(url, callback) {
var request = window.ActiveXObject ?
new ActiveXObject('Microsoft.XMLHTTP') :
new XMLHttpRequest;
request.onreadystatechange = function() {
if (request.readyState == 4) {
request.onreadystatechange = doNothing;
callback(request, request.status);
}
};
request.open('GET', url, true);
request.send(null);
}
function doNothing() {}
//]]>
</script>
</head>
<body onload="load()">
<div id="map"></div>
</body>
</html>
z-index 的值从 100 到 200 不等,增量为 10,具体取决于代数。不过,我也试过将它们设为 9100 到 9200,以及其他各种东西。
我看到有人建议图标需要 CSS "position" 才能使 z-index 正常工作。不过我试过了
#map img[src^='/myfamilyroots/images'] {position:relative!important;}
以及该主题的许多变体都没有成功。
这让我发疯。据我所知,我已遵循 Google 地图参考指南,但我所做的任何事情都不会改变标记的显示方式。
zIndex
应为数字类型,但 getAttribute()
总是 returns 字符串。
在分配 zIndex 之前将字符串转换为数字
var z_index = Number(markers[i].getAttribute("z_index"));