谷歌地图js API v3:创建没有内存泄漏的地图/将地图对象移动到不同的div

时间:2012-10-03 15:04:39

标签: javascript google-maps memory

我正在制作相当于幻灯片窗格的内容,以显示需要有0次内存泄漏的不同页面。我想显示该区域的谷歌地图,但地图附加的div将定期被不同的内容替换,然后返回。我理论上可以将div移出窗格并隐藏它,稍后再显示它,但这将是最后的手段,因为我觉得在背景中将隐藏的div附加到页面确实不是一个好主意。有没有办法从div中分离一个地图然后重新附加它,或者有没有办法在V3中销毁地图?我想如果你摆脱了div,那么地图就会在其中生存,但是这个测试会泄漏内存,就像不破坏div一样:

<!DOCTYPE html>
<html>
  <head>
    <script src = "/javascript/jquery.js"></script>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map_canvas { height: 100% }
    </style>
    <script type="text/javascript"
      src="http://maps.googleapis.com/maps/api/js?key=MYKEY&sensor=false">
    </script>
    <script type="text/javascript">
    function initialize() {
        var mapOptions = {
          center: new google.maps.LatLng(-34.397, 150.644),
          zoom: 8,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),
            mapOptions);
        setTimeout(remMap,3000);
        setTimeout(mapempty,6000);
      }
    function mapempty(){
          $("body").append("<div id = 'map_canvas'></div>");
          initialize();
        }
    function remMap(){
          remove(document.getElementById("map_canvas"));
        }

        function remove(selection){
          selection.parentNode.removeChild(selection);
            }
    </script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:100%; height:100%"></div>
  </body>
</html>

编辑:与我之前读到的相反,谷歌地图V3确实支持自定义卸载;地图仅在页面关闭时卸载,而不是在其div被销毁时卸载。似乎将div隐藏到隐藏的窗口是最好的选择

1 个答案:

答案 0 :(得分:1)

谷歌地图V3 支持自定义卸载;地图仅在页面关闭时卸载,而不是在其div被销毁时卸载。

V2有GUnload