gpt4 book ai didi

angularjs - 传单在显示和隐藏时会出现 Angular 问题?想要摆脱 $timeout

转载 作者:行者123 更新时间:2023-12-04 15:55:17 25 4
gpt4 key购买 nike

我有一个正在创建的传单,其中 L.map('mapelement') 被调用。问题是,如果我单击“隐藏”传单 map 的按钮,然后再次单击该按钮以显示,则传单 map 不会显示。但是,当我在创建 map 之前在链接函数中放入 setTimeout 并将其设置为 2 秒时, map 每次都会显示(尽管我必须等待 2 秒)。在我的自定义“传单 map ”指令中使用 $timeout 来显示和隐藏是否有更好的选择?

最佳答案

我在没有看到您的任何代码的情况下创建了一个单张 map 指令的天真示例,并且正在通过 ng-show 切换 map 的显示。它在没有任何 $timeout 的情况下工作。如果不查看任何代码或不知道您尝试切换 map 显示的方式,就很难诊断出问题的根源。

angular.module('demo', [])

.directive('leafletMap', function() {
return {
restrict: 'E',
scope: {
mapOptions: '&'
},
template: '<div><button ng-click="toggleShow()">Toggle Map</button><div class="demo-map" ng-show="isShown"></div></div>',
link: function(scope, elem, attrs) {
// Find element to bind to map
var mapElem = elem.children().find('div')[0],
// get map options from isolate scope
mapOptions = scope.mapOptions();

// State of hide/show
scope.isShown = true;

// Create Map.
var map = L.map(mapElem, mapOptions);

// Just taken from leaflet example
L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpandmbXliNDBjZWd2M2x6bDk3c2ZtOTkifQ._QA7i5Mpkd_m30IGElHziw', {
maxZoom: 18,
attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, ' +
'<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' +
'Imagery © <a href="http://mapbox.com">Mapbox</a>',
id: 'mapbox.streets'
}).addTo(map);

// method to toggle the shown/hidden state of map
scope.toggleShow = function() {
scope.isShown = !scope.isShown;
};

// cleanup on element destroy
elem.on('$destroy', function() {
map.remove();
});
}
};
})

.controller('DemoController', function() {
this.mapOptions = {
center: [51.505, -0.09],
zoom: 13
};


});
.demo-map {
height: 500px;
}
<script src="//cdn.leafletjs.com/leaflet/v0.7.7/leaflet.js"></script>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<link rel="stylesheet" href="//cdn.leafletjs.com/leaflet/v0.7.7/leaflet.css" />
<div ng-app="demo" ng-controller="DemoController as ctrl">
<leaflet-map map-options="ctrl.mapOptions"></leaflet-map>
</div>

关于angularjs - 传单在显示和隐藏时会出现 Angular 问题?想要摆脱 $timeout,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36485574/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com