@beduin01

Как динамически добавить данные в Leaflet?

Есть функция `drawmap` со следующим телом:

function drawmap()
{
    
   var cities = new L.LayerGroup();

    var mbAttr = '<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ',
    mbUrl = 'https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpandmbXliNDBjZWd2M2x6bDk3c2ZtOTkifQ._QA7i5Mpkd_m30IGElHziw';

    var grayscale  = L.tileLayer(mbUrl, {id: 'mapbox.light', attribution: mbAttr}),
      streets  = L.tileLayer(mbUrl, {id: 'mapbox.streets',   attribution: mbAttr});

    var map = L.map('map', {
      center: [49, 20],
      zoom: 3,
      minZoom: 2,
      layers: [grayscale, cities]
    });

var drawnItems = new L.FeatureGroup();
map.addLayer(drawnItems);

// Вот эти функции
// var imageUrl = 'http://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg';
// var imageBounds = [[40.712216, -74.22655], [46.773941, -79.12544]];
// L.imageOverlay(imageUrl, imageBounds).addTo(map);

}


Внутри есть функции добавления растрового изображения. Их я закомментировал. Если их раскомментить, то изображение добавится. Проблема в том, что во внешнем фреймворке, который я использую (Vue-js) мне нужно в начале отрисовать карту (вызвать функцию drawmap) и только потом по событию добавить данные. Т.е. сразу в функцию данные я передать не могу. Как мне данные можно добавить динамически?

addTo(map) по отношению к L.imageOverlay это метод или что?

------

Я пробовал сделать как-то так:

ready: function()
          { 

              //drawmap.call(this)
             drawmap.this;
             drawmap()
             
              // this.map = L.map('map').setView([51.505, -0.09], 13);
          },

          methods: 
          { 
              removeSingleRasterFromList: function (index) 
              {
                this.rasters_previews_list.splice(index, 1)
              },

              foo : function()
              {
                console.log("foo from main");

                var imageUrl = 'http://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg';
                var imageBounds = [[40.712216, -74.22655], [46.773941, -79.12544]];
     
                L.imageOverlay(imageUrl, imageBounds).addTo(map); // но вылетает ошибка: TypeError: t.addLayer is not a function
              }
          }
  • Вопрос задан
  • 602 просмотра
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
24 нояб. 2024, в 14:37
3000 руб./в час
24 нояб. 2024, в 13:04
500 руб./в час
24 нояб. 2024, в 12:29
3000 руб./за проект