У меня появляется всплывающее окно Infobox (информационное окно с дополнительными элементами управления), когда пользователь нажимает на маркер на карте. В этом всплывающем окне я сейчас пытаюсь вставить слайдер изображений jQuery, в частности NivoSlider.
Проблема. Однако этот слайдер изображений работает только на обычной HTML-странице и вообще не работает в информационном окне. Мне нужно, чтобы изображение работало внутри информационного окна.
Код jQuery/JS
Часть, которая загружает слайдер изображений jQuery, заключена в <div id="slider class="nivoSlider"><img...../><img....../></div>"
$(window).load(function() {
$('#слайдер').nivoSlider(); //загружает нивослайдер в div #slider
$("#search_button").click(function(e){ e.preventDefault(); var search_location = $("#search_location").val(); $.getJSON(.......... ..............., функция () {
for( i = 0; i < json.length; i++) {
// Place markers on map
var latLng = new google.maps.LatLng(json[i].lat, json[i].lng);
var marker = new google.maps.Marker({
position: latLng,
map: map
});
markers.push(marker);
// Create infowindows
var boxText = '<div id="infobox"> \
<div id="infobox_header_title"> \
<span id="infobox_header_price">$' + json[i].price + '</span> \
<span id="infobox_header_room">' + json[i].bedroom + 'br </span> \
<span id="infobox_header_address">' + json[i].address_1 + '</span> \
</div> \
<div id="slider" class="nivoSlider"> \
<img src="/images/cl/' + json[i].photos[0] + '.jpg" /> \
<img src="/images/cl/' + json[i].photos[1] + '.jpg" /> \
</div> \
</div>';
var infoboxOptions = {
content: boxText,
disableAutoPan: false,
maxWidth: 0,
pixelOffset: new google.maps.Size(-140, 0),
zIndex: null,
boxStyle: {
},
closeBoxMargin: "10px 2px 2px 2px",
closeBoxURL: "http://www.google.com/intl/en_us/mapfiles/close.gif",
infoBoxClearance: new google.maps.Size(1, 1),
isHidden: true,
pane: "floatPane",
enableEventPropagation: false
};
var infobox = new InfoBox(infoboxOptions);
infobox.open(map, markers[i]);
infoboxes.push(infobox);
// Create Listeners
markers[i]._index = i;
google.maps.event.addListener(markers[i], 'click', function() {
//infoboxes[this._index].open(map, markers[i]);
infoboxes[this._index].show();
});
};
// Fill screen with markers
mapAutoCenter(markers);
});
Что, по моему мнению, является причиной этого: Вероятно, это связано с тем, что <div>
в информационном поле не создается, когда $('#slider').nivoSlider()
вызывается в самом начале.
Дополнительная информация: я использую Google Maps API V3 с PHP и фреймворком Codeigniter.