joh*_*eur 5 jquery dom reference jquery-on
我知道有.on,并.live (deprecated)可以从JQuery的,但这些假设你想增加事件处理程序动态添加的元素,我不的一个或多个事件.我只需要引用它,这样我就可以访问它的一些属性.
更具体地说,有多个这样的动态元素都带有class="cluster"set,每个动态元素都有:title属性,top属性和left属性的不同值.
这些jquery选项都不起作用:
var allClusters = $('.cluster');
var allClusters2 = $('#map').children('.cluster');
var allClusters3 = $('#map').find('.cluster');
Run Code Online (Sandbox Code Playgroud)
同样,我不想附加任何事件处理程序,所以.on即使我劫持它,添加一个虚假事件,一个doNothing处理程序,然后只是引用我的属性,似乎不是正确的解决方案.
必须有一个更好的解决方案.有任何想法吗?
更新:
我错误地说明了标题,因为我的意思是说元素是动态添加到DOM的,而不是通过JQuery.标题已更新.
我想到了。元素没有显示,因为DOM 尚未更新。
我正在使用 Google 地图和MarkerClustererPlus来提供更多上下文,当我使用 MarkerClustererPlus 添加地图标记时,它们在添加后的 javascript 代码中不可用。
添加谷歌地图事件监听器到我的谷歌地图解决了这个问题:
google.maps.event.addListener(myMarkerClusterer, 'clusteringend', function () {
// access newly added DOM elements here
});
Run Code Online (Sandbox Code Playgroud)
添加该侦听器后,上述所有 JQuery 选择器和/或方法都可以正常工作:
var allClusters = $('.cluster');
var allClusters3 = $('#map').find('.cluster');
Run Code Online (Sandbox Code Playgroud)
虽然这个没有,但那是因为它只找到父母的直系后代:
var allClusters2 = $('#map').children('.cluster');
Run Code Online (Sandbox Code Playgroud)