Jawaban:
Saya kira Anda ingin kontennya diubah setelah beberapa peristiwa terjadi, seperti mouseover, contextmenu, atau apa pun.
Untuk melakukannya, Anda dapat menggunakan kode berikut:
//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')
});
Seperti yang Anda lihat, Anda dapat mengakses popup untuk marker yang diinginkan menggunakan metode marker._popup, dan kemudian menggunakan metode setContent untuk mengubah teks di dalamnya.
referensi metode popup.setContent
Berikut ini beberapa kode di Plunker yang menunjukkan ini: http://plnkr.co/edit/vjS495QPXiJpKalrNpvo?p=preview
_popup
memiliki garis bawah di depannya untuk menunjukkan bahwa itu adalah contoh pribadi / anggota, dan tidak boleh diakses secara langsung. API yang benar adalah Layer.setPopupContent () . misalnya
marker.setPopupContent(newContent);
Mungkin terlambat untuk menjawab, tetapi bagi yang lain, saya pikir cara terbaik ada di sini
$('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;
});