Ответы:
Я полагаю, вы хотите, чтобы содержимое было изменено после какого-либо события, например, при наведении курсора, в контекстном меню или чем-то еще.
Для этого вы можете использовать следующий код:
//marker creation
var marker = L.marker([44.63, 22.65]).bindPopup('something').addTo(map);
marker.openPopup();
//changing the content on mouseover
marker.on('mouseover', function(){
marker._popup.setContent('something else')
});
Как видите, вы можете получить доступ к всплывающему окну для нужного маркера, используя метод marker._popup, а затем использовать метод setContent для изменения текста внутри него.
ссылка на метод popup.setContent
Вот некоторый код на Plunker, демонстрирующий это: http://plnkr.co/edit/vjS495QPXiJpKalrNpvo?p=preview
_popup
перед ним подчеркивание, указывающее, что это экземпляр private / member, и к нему нельзя обращаться напрямую. Правильным API является Layer.setPopupContent () . например
marker.setPopupContent(newContent);
Возможно, будет поздно, чтобы ответить, но для других, я думаю, что лучшие способы здесь
$('button').click(function() {
// Update the contents of the popup
$(popup._contentNode).html('The new content is much longer so the popup should update how it looks.');
// Calling _updateLayout to the popup resizes to the new content
popup._updateLayout();
// Calling _updatePosition so the popup is centered.
popup._updatePosition();
return false;
});