【发布时间】:2016-04-17 11:42:13
【问题描述】:
仅供参考,我是 AngularJS 的新手。我正在尝试将在 Google 地图中选择的标记的坐标存储在一个变量中。一旦我在地图上选择了一个点,我就能够记录坐标,但我无法弄清楚为什么 $scope.map.markers 在 addSesh() 中返回“未定义”。如果您需要进一步说明,请告诉我。提前致谢!
angular
.module('surfSup')
.controller('SessionController', function($scope, $location, SessionService, CacheEngine, $rootScope) {
$scope.addSesh = addSesh;
function addSesh () {
$scope.sessionObjs = {
time: $scope.time ? $scope.time.toISOString().slice(0,19) : "",
isSurf: $scope.suppy,
location: $scope.location
};
console.log("session obj", $scope.sessionObjs);
console.log("map coords: ", $scope.map.markers);
SessionService.addSession($scope.sessionObjs).then(function(res){
console.log('session created', res);
$location.path('/sessions');
}
$scope.map = {
center: {
latitude: 32.7799400,
longitude:-79.9341970
},
zoom: 11,
markers: [],
events: {
click: function (map, eventName, originalEventArgs) {
var e = originalEventArgs[0];
var lat = e.latLng.lat(),lon = e.latLng.lng();
var marker = {
id: Date.now(),
coords: {
latitude: lat,
longitude: lon
}
};
$scope.map.markers.push(marker);
console.log('MARKERS:', $scope.map.markers);
window.glow = $scope.map.markers;
$scope.$apply();
}
}
};
【问题讨论】:
标签: javascript angularjs google-maps google-maps-api-3