我知道
JQuery提供了.on和.live(已弃用),但是这些假设您希望将事件处理程序附加到动态添加元素的一个或多个事件中,而我不这样做.我只需要引用它,这样我就可以访问它的一些属性.
更具体地说,有这样的多个动态元素都设置了class =“cluster”,并且每个动态元素都有:title属性,top属性和left属性的不同值.
这些jquery选项都不起作用:
var allClusters = $('.cluster'); var allClusters2 = $('#map').children('.cluster'); var allClusters3 = $('#map').find('.cluster');
同样,我不想附加任何事件处理程序,所以.on似乎不是正确的解决方案,即使我要劫持它,添加一个虚假事件,一个doNothing处理程序,然后只是引用我的属性.
必须有一个更好的解决方案.有任何想法吗?
解决方法
我想到了.元素没有显示,因为DOM还没有更新.
我正在使用Google Maps和MarkerClustererPlus来提供更多上下文,当我使用markerclustererplus添加地图标记时,它们在添加后的javascript代码中不可用.
将google maps event listener添加到我的谷歌地图修复了问题:
google.maps.event.addListener(myMarkerClusterer,'clusteringend',function () { // access newly added DOM elements here });
一旦我添加了该侦听器,所有上述JQuery选择器和/或方法都可以正常工作:
var allClusters = $('.cluster'); var allClusters3 = $('#map').find('.cluster');
虽然这个没有,但那是因为它只找到了父母的直接后代:
var allClusters2 = $('#map').children('.cluster');