我很难让传单地图在我的应用程序的 div 内正确呈现。
可能值得一提的是,我正在使用 AngularJS、Angular-Material(具有基于 Flex 的布局)和 ui-router,因此 div 所在的页面是用户调用操作导航到该页面时加载的状态的模板(例如,通过点击导航栏项目)。
我的状态模板文件非常简单:
<md-card>
<div id='map' style="width: 500px; height: 500px;"></div>
</md-card>
在该州的控制器文件中,我有以下传单地图初始化代码:
this.map = L.map('map').setView([51.505, -0.09], 13);
L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
}).addTo(this.map);
当地图渲染时,图块不会受到我的 div 的限制,它们会溢出:
我的 dom 结构可以在下面找到
我的 md-card 的父元素变得可滚动,因此当我向下滚动时,我也开始看到其他图块:
我最初的想法是,在 div 有时间渲染之前,我可能太早尝试渲染地图了。因此,我尝试在超时(2 秒)内包装我的地图初始化代码,并且我确实看到在加载状态时首先显示我的白色 md 卡,然后在 2 秒延迟后显示图块,但它们再次按照我的截图。
我唯一能想到的另一件事是,也许使用 flex 会产生效果,但是我在保存地图的 div 上指定了明确的高度和宽度,所以我认为地图会遵循该尺寸。
任何人都可以提供关于这里可能发生的事情的任何建议\帮助吗?
Thanks