Odpowiedzi:
Przypuszczam, że chcesz zmienić treść po wystąpieniu jakiegoś zdarzenia, takiego jak najechanie myszą, menu kontekstowe lub cokolwiek innego.
Aby to zrobić, możesz użyć następującego kodu:
//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')
});
Jak widać, można uzyskać dostęp do wyskakującego okienka dla żądanego znacznika za pomocą metody marker._popup, a następnie użyć metody setContent, aby zmienić tekst w nim umieszczony.
Odwołanie do metody popup.setContent
Oto kod demonstrujący to w Plunker: http://plnkr.co/edit/vjS495QPXiJpKalrNpvo?p=preview
_popup
ma przed nim znak podkreślenia wskazujący, że jest to instancja prywatna / członkowska i nie należy uzyskiwać do niej bezpośredniego dostępu. Poprawnym interfejsem API jest Layer.setPopupContent () . na przykład
marker.setPopupContent(newContent);
Może być za późno, by odpowiedzieć, ale dla innych myślę, że najlepsze sposoby są tutaj
$('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;
});