@Artem0071
Безработный mr. Junior

Как подключить апи от яндекса в VueJS?

Добрый день
Хочу подключить карту от яндекса, как это сделать?

В хеаде прописываю:
<script src="https://api-maps.yandex.ru/2.1/?lang=ru_RU" type="text/javascript"></script>

в компоненте :
<template>
  <div id="app">
    <img src="./assets/logo.png">
    <router-view></router-view>
    <div id="map" style="width: 600px; height: 400px"></div>
  </div>
</template>

<script>
export default {
  name: 'app',
  created () {
    var map = new ymaps.Map("map", {
      center: [55.76, 37.64],
      zoom: 7
    });
  }
}
</script>


На что в консоли выводит:
ymaps.Map is not a constructor

Я так понимаю, что Vue просто не видит вне себя этот конструктор, так что как такое можно реализовать?
  • Вопрос задан
  • 4974 просмотра
Решения вопроса 1
AppFA
@AppFA
Frontend developer at Yandex
Если вы подключили скрипт в хедере, то он уже будет доступен в глобальной области видимости. Если бы это было не так, то вы бы получили другу ошибку, у вас же явно сказано что ymaps это не конструктор. Значит проблема в названии переменой скорее всего нужно с большой буквы написать класс, т.к. в JS все переменные чувствительны к регистру и как правило классы всегда пишутся с заглавной буквы:
var map = new YMaps.Map(...)
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 2
@grin_09
ymaps.ready(function(){
	var map = new ymaps.Map("map", {
		center: [55.76, 37.64], 
		zoom: 7
	});
});
Ответ написан
Комментировать
kleinmaximus
@kleinmaximus
Senior Full-stack Javascript Developer
Есть готовый компонент - https://github.com/PNKBizz/vue-yandex-map
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект
22 нояб. 2024, в 23:55
3000 руб./за проект