javascript - 谷歌地图 - 未捕获的类型错误

标签 javascript jquery google-maps google-maps-api-3

我有一个按钮,如果单击该按钮,则会在 map 上显示用户位置。目前很难,我收到此错误 Uncaught TypeError: Cannot set property 'position' of undefined

这是我的代码:

            <div class="col-sm-offset-4 col-sm-4">
             <input type="button" value="Show my location on Map" id="mapButton">
                <article></article>
            </div>

$('#mapButton').click(function() {
$( "#mapcontainer" ).remove();
function success(position){
  var mapcanvas = document.createElement('div');
  mapcanvas.id = 'mapcontainer';
  mapcanvas.style.height = '300px';
  mapcanvas.style.width = '300px';

  document.querySelector('article').appendChild(mapcanvas);

  var coords = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
  alert(coords);
  var options = {
    zoom: 15,
    center: coords,
    mapTypeControl: false,
    navigationControlOptions: {
        style: google.maps.NavigationControlStyle.SMALL
    },
    mapTypeId: google.maps.MapTypeId.ROADMAP
  };
  var map =  new google.maps.Map("mapcontainer",options)[0];

  marker = new google.maps.Marker({
      position: coords,
      map: map,
      title:"You are here!"
  });
}

if (navigator.geolocation) {
  navigator.geolocation.getCurrentPosition(success);
} else {
  error('Geo Location is not supported');
}

});

为什么会抛出这个错误?

JSFiddle

最佳答案

map 的第一个参数是一个 div 元素。不要传递“mapcontainer”,而是传递

document.getElementById("mapcontainer")

Working example

 var map =  new google.maps.Map(document.getElementById("mapcontainer"),options)[0];
      var marker = new google.maps.Marker({
          'position': coords,
          map: map,
          title:"You are here!"
      });

关于javascript - 谷歌地图 - 未捕获的类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25546576/

相关文章:

javascript - 使用 Javascript 将 href 替换为 onclick

jquery - 如何对 svg 过滤器 feComponentTransfer 进行动画处理?

html - 谷歌地图标记不拖动

javascript - 用折线连接多个标记

javascript - 设置 AngularJS 时遇到问题

javascript - Css 属性选择器和 javascript

javascript - ReactJS - 如何设置 React 日历样式

javascript - 如何仅在此 block 中显示元素?

javascript - 如何通过javascript在thymeleaf中根据数据库进行复选框

android - 谷歌地图未以所需位置为中心