0

メモリ リークをゼロにする必要があるさまざまなページを表示するために、スライドショー ペインに相当するものを作成しています。その地域のGoogleマップを表示したいのですが、マップが添付されている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>

編集:以前に読んだこととは反対に、Google マップ V3 はカスタム アンロードをサポートしていないようです。マップは、div が破棄されたときではなく、ページを閉じたときにのみアンロードされます。非表示のウィンドウにdivを添付するのが最善の策のようです

4

1 に答える 1

1

グーグルマップV3はカスタムアンロードをサポートしていません。マップは、divが破棄されたときではなく、ページを閉じるときにのみアンロードされます。

V2にはGUnloadがあります

于 2012-10-04T14:47:46.110 に答える