Leaflet.js: Как удалить несколько слоев с карты

Я использую Leaflet.js для карты. Теперь я хочу удалить добавленные слои с карты. При нажатии кнопки ввода # все отмеченные флажки должны быть заменены на непроверенные, а все соответствующие слои должны быть удалены с карты.

Для удаления слоя с карты нужен идентификатор слоя. Этот идентификатор равен идентификатору соответствующего флажка. Вот почему я использую jQuery, чтобы получить идентификаторы всех отмеченных флажков и сохранить их значение в объекте, называемом здесь someObj.idsChecked .

Когда я пытаюсь использовать сохраненное значение val , чтобы удалить один слой, он не работает, в то время как console.log отображает требуемый стоимость. Вот например: mapcat52.

При вставке предыдущего идентификатора, жестко запрограммированного в функцию, подобную map.removeLayer (mapcat52) , она работает как положено.

Где ошибка в моем коде или моих мыслях?
Любая помощь очень ценится.

HTML

<input type="button" id="selectnone" value="deselect all" />

<!-- checkboxes  --> 
<input id="mapcat52" type="checkbox" name="maplayer" class="maplayer"> 
<label for="mapcat52">Map Layer One</label>

<input id="mapcat53" type="checkbox" name="maplayer" class="maplayer"> 
<label for="mapcat53">Map Layer Two</label>

...

JS:

$('#selectnone').click(function() {
    var someObj = {};
    someObj.idsChecked = [];

    $("input:checkbox").each(function() {
        if ($(this).is(":checked")) {

            someObj.idsChecked.push($(this).attr("id"));
        }
    }).attr('checked', false);

    $.each(someObj.idsChecked,function(id, val) {

          // displays the wanted value, e.g. "mapcat52" if checkbox with this id is checked
          console.log(val);

          // does not work: inserted value
          map.removeLayer(val); 

          // works: hard coded value of the leaflet.js/input id
          map.removeLayer(mapcat52); 
        });

});
8
задан LuNarez 30 August 2013 в 06:07
поделиться