Как добавить метку в маркер карты Google? (Ошибка: InvalidValueError: setLabel: не строка; нет текстового свойства) - PullRequest
0 голосов
/ 03 сентября 2018

Я хочу добавить метку на маркер карты Google в зависимости от количества моих местоположений GPS. Я получил свои данные в своей базе данных. Я могу добавить маркеры на карту, но я не могу добавить маркеры внутри маркера.

for(var i = 0; i < data.length; i++) {
   var coords = data[i].GPSCoordinates.split(',');
   var position = new google.maps.LatLng(coords[0], coords[1]);
   var labels = i + 1;
   addMarker(position, map, labels);
}

function addMarker(location, map, label) {
   var marker = new google.maps.Marker({
       position: location,
       map: map,
       label: label
   });
}

1 Ответ

0 голосов
/ 03 сентября 2018

Я получаю ошибку JavaScript с вашим кодом: InvalidValueError: setLabel: not a string; and no text property. Значение, присвоенное свойству label , должно быть строкой (или анонимным объектом MarkerLabel). Код в настоящее время присваивает номер. Изменения:

var labels = i + 1;

до:

var labels = ""+ (i + 1);

подтверждение концепции скрипки

screenshot of resulting map

фрагмент кода:

function initialize() {
  var map = new google.maps.Map(
    document.getElementById("map_canvas"), {
      center: new google.maps.LatLng(37.4419, -122.1660756),
      zoom: 13,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });
  var data = [{GPSCoordinates: "37.4419, -122.1419"},
    {GPSCoordinates: "37.4529598, -122.1817252"},
    {GPSCoordinates: "37.4335499, -122.2030209"},
    {GPSCoordinates: "37.424106, -122.1660756"}
  ]
  for (var i = 0; i < data.length; i++) {
    var coords = data[i].GPSCoordinates.split(',');
    var position = new google.maps.LatLng(coords[0], coords[1]);
    var labels = "" + (i + 1);
    addMarker(position, map, labels);
  }

  function addMarker(location, map, label) {
    var marker = new google.maps.Marker({
      position: location,
      map: map,
      label: label
    });
  }
}
google.maps.event.addDomListener(window, "load", initialize);
html,
body,
#map_canvas {
  height: 100%;
  width: 100%;
  margin: 0px;
  padding: 0px
}
<script src="https://maps.googleapis.com/maps/api/js"></script>
<div id="map_canvas"></div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...