Я использую leaflet-angular-directive, я успешно отображаю объекты в таблице и на карте, хотя я добился фильтрации с помощью поискового ввода, влияющего только на объекты geojson в таблице.
Моя цель: сделать так, чтобы фильтрация при поиске влияла на объекты geojson в таблице и на карте.
Мой модуль
var AppMapDirectory = angular.module('DirectoryAppMap', ['ngResource', 'leaflet- directive']);
Моя фабрика
AppMapDirectory.factory("Directory", function($resource) {
return $resource("json/result.json", {}, {
get: {
method: "GET",
cache: true
}
});
});
Мой контроллер
AppMapDirectory.controller("DirectoryMapList", function($scope, Directory) {
Directory.get(function(data) {
$scope.hf_directory = data.features;
function onEachFeature(feature, layer) {
layer.bindPopup("<b>Wardname:</b> " + feature.properties.name +
"<br><b>Category:" + feature.properties.category + "");
}
angular.extend($scope, {
geojson: {
data: $scope.hf_directory,
onEachFeature: onEachFeature
}
});
});
angular.extend($scope, {
defaults: {
tileLayer: "https://dnv9my2eseobd.cloudfront.net/v3/foursquare.map-ikj05elx/{z}/{x}/{y}.png",
maxZoom: 14,
minZoom: 3
},
center: {
lat: 8.1238,
lng: 11.8777,
zoom: 2
}
});
});
Мой шаблон
<div ng-app="DirectoryAppMap" ng-controller="DirectoryMapList">
<ul>
<li><input ng-model="search.properties.name" placeholder="Name" ></li>
<li><input ng-model="search.properties.category" placeholder="Category"></li>
</ul>
<table>
<thead>
<tr>
<th>Name</th>
<th>Category</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="hf in hf_directory| filter:search">
<td>{{ hf.properties.name }}</td>
<td>{{ hf.properties.category }}</td>
</tr>
</tbody>
</table>
<div leaflet id="map" center="center" defaults="defaults" geojson="geojson">
</div>
</div>
Может быть, кто-нибудь может указать мне правильное направление, чтобы я знал, что делаю неправильно, я пытался привязать поиск к листовке разными способами, но безуспешно, на самом деле я думаю, что это не то, что следует делать на стороне шаблона? Но скорее в опциях для geojson, как фильтр? Правильно ли это сейчас?
Я использовал директиву ng-repeat, но тогда у меня были тысячи карт, может быть, можно использовать ng-repeat и иметь только одну карту?