I am trying to write simple example with google maps and markers but i faces with error:
Uncaught RangeError: Maximum call stack size exceeded
js:
$(document).ready(function() {
var map;
var elevator;
var myOptions = {
zoom: 1,
center: new google.maps.LatLng(0, 0),
mapTypeId: 'terrain'
};
map = new google.maps.Map($('#map_canvas')[0], myOptions);
var markers = [];
coords = [{
lat: 55,
lng: 37
}];
for (var x = 0; x < coords.length; x++) {
var latlng = new google.maps.LatLng(x.lat, x.lng);
var marker = new google.maps.Marker({
position: latlng,
map: map
});
markers.push(marker);
}
fitBounds();
function fitBounds() {
var bounds = calculateBounds();
if (bounds != undefined) {
map.fitBounds(bounds);
}
}
function calculateBounds() {
var allMarkers = markers;
if (allMarkers.length > 0) {
var bounds = new google.maps.LatLngBounds();
for (i = 0; i < allMarkers.length; i++) {
bounds.extend(allMarkers[i].getPosition());
}
}
return bounds;
}
});
The error
Uncaught RangeError: Maximum call stack size exceeded
when callingfitBounds
usually means you have calledbounds.extend
with an invalidgoogle.maps.LatLng
object.This is incorrect (x.lat and x.lng are undefined):
It yields latlng with lat: NaN, lng: NaN
Which isn't valid.
should be:
updated fiddle