2012-04-25 74 views
3

单张是呈现,因为我可以看到它在DOM中的所有元素,但没有其他任何东西来到生活中。我看到的只有灰色。Leaflet地图元素坐在DOM中但不渲染?

我可以让地图贴图出现的唯一方法是,如果我删除位置:绝对地图容器上,但会创建一堆混乱的地图贴图。我检查了GIT的历史,看看我是否意外地改变了风格,但没有运气。

下面的代码初始化地图:

// init everything on page show 
$("#map").live('pageshow',function() { 
    if(window.localStorage.getItem("lat")!=undefined) { var lat = window.localStorage.getItem("lat")} else { var lat = '49.264'; } 
    if(window.localStorage.getItem("lng")!=undefined) { var lng = window.localStorage.getItem("lng")} else { var lng = '-123.123'; } 
    try {   
     var map = window.map 
     map = new L.Map('map-container'); 
     var cloudmadeUrl = 'http://{s}.tile.cloudmade.com/006282296d334e66a593e55aca6b5ce0/54803/256/{z}/{x}/{y}.png'; 
     var cloudmadeAttribution = 'Map Data © 2011 OpenStreetMap'; 
     var cloudmade = new L.TileLayer(cloudmadeUrl, {maxZoom: 18, attribution: cloudmadeAttribution}); 
     map.setView(new L.LatLng(lat, lng), 12).addLayer(cloudmade); 
     map.invalidateSize(); 
    } catch(e) {console.log(e)} 
    userMarkers[1] = new L.Marker(new L.LatLng(lat,lng) , {icon: new iconUser, clickable: true}); 
    map.addLayer(userMarkers[1]); 
}); 

环境包括jQuery Mobile的。不幸的是,控制台不记录任何错误,并且当我检查它时,上面的localStorage确实拥有有效的LatLng值。

截图: screenshot

任何的猜测?

回答

4

我不知道这个问题是如何开始的,但要修复它我去和删除所有地图容器样式,然后宣布:

#map-container { 
    position:absolute; 
    top:0; 
    bottom:0; 
    left:0; 
    right:0; 
    margin: 0; 
    padding: 0; 
} 

而现在的问题是固定的。我以前从未使用过这种造型,所以我无法推测问题是如何发生的。