我对我设置的当前代码有点困难。我正在设置一个包含各种项目的页面。点击时,这个想法是会有一个全尺寸的图像弹出。有些项目有多个图像,所以我还添加了幻灯片放映属性。我通过让jquery确定img的宽度和高度来确定弹出窗口大小,以便每个窗口将根据第一个图像具有唯一的大小。当我单独设置这两个脚本时,它们工作正常,但现在我将它们一起实施,img的大小未被读取。另一个问题是,由于幻灯片处理图像列表,它隐藏了除第一个以外的所有图像......但是,此过滤器也将其他所有图像隐藏在其他项目中。jquery激活多个幻灯片和弹出窗口
我还想定位打开的弹出式窗口,水平居中并从顶部开始10%...我在那里为容器窗口设置了代码,但由于某些原因,我似乎无法使其工作,因为它使我一个奇怪的位置,所以我只是将它设置为10%,自左25%......
这里是我使用不带幻灯片放映的弹出窗口代码:
<div class="projectPopup" id="lova">
<a class="close">Close ×</a>
<img src="/img/lova_popup_slide01.jpg" alt="" />
<p class="description">Description</p>
</div>
这里是我的代码我用幻灯片放映弹出:
<div class="projectPopup" id="rbex">
<a class="close">Close ×</a>
<ul class="slideImages">
<li><a href="#slide1" class="active" >1</a> / </li>
<li><a href="#slide2">2</a> / </li>
<li><a href="#slide3">3</a> / </li>
<li><a href="#slide4">4</a> / </li>
<li><a href="#slide5">5</a> / </li>
<li><a href="#slide6">6</a> / </li>
<li><a href="#slide7">7</a> / </li>
<li><a href="#slide8">8</a></li>
</ul>
<img id="slide1" src="/img/rbex_popup_slide01.jpg" alt="Image 1 slideshow" />
<img id="slide2" src="/img/rbex_popup_slide02.jpg" alt="Image 2 slideshow" />
<img id="slide3" src="/img/rbex_popup_slide03.jpg" alt="Image 3 slideshow" />
<img id="slide4" src="/img/rbex_popup_slide04.jpg" alt="Image 4 slideshow" />
<img id="slide5" src="/img/rbex_popup_slide05.jpg" alt="Image 5 slideshow" />
<img id="slide6" src="/img/rbex_popup_slide06.jpg" alt="Image 6 slideshow" />
<img id="slide7" src="/img/rbex_popup_slide07.jpg" alt="Image 7 slideshow" />
<img id="slide8" src="/img/rbex_popup_slide08.jpg" alt="Image 8 slideshow" />
<p class="description">Description</p>
</div>
这里是Jquery的我使用:
$(document).ready(function() {
//Hiding all Divs
$(".projectPopup").hide();
//Setting DIV name to nothing
var actualOpenID = "";
//Slideshow Image to hide rest
var image = $('.projectPopup > img');
image.hide().filter(':first').show();
//Determine popup width and height
var container = $(".projectPopup", this);
var popupWidth = container.find("img").width()+10;
var popupHeight = container.find("img").height()+60;
//Determine window width and height
var windowWidth = document.documentElement.clientWidth;
var windowHeight = document.documentElement.clientHeight;
container.css("width" , popupWidth);
container.css("height" , popupHeight);
//Find & Open
$(".projectThumb").click(function(){
if (actualOpenID !== "") {
$("div[id="+actualOpenID+"]").hide();
}
var newID = $(this).children("img").attr("name");
$("div[id="+newID+"]").show();
actualOpenID = newID;
});
//Set popup CSS
container.css({"position": "fixed", "background": "#000", "top": "10%", "left": "20%"});
$('ul.slideImages li a').click(function() {
if (this.className.indexOf('active') == -1){
image.hide();
image.filter(this.hash).show();
$('ul.slideImages li a').removeClass('active');
$(this).addClass('active');
}
return false;
});
//Close property
$("a.close").click(function (e) {
e.preventDefault();
$(this).parent().hide();
actualOpenID = "";
});
});
的问题可以在这里看到:
自身工作幻灯片浏览: http://www.samuelfarfsing.com/slides.php
任何帮助是非常赞赏!
嘿TB, 非常感谢。这工作得很好。一个问题,有没有办法让它在使用绝对位置时正确居中?原因在于有些图像很大,会离开屏幕并且滚动条会隐藏起来。当我将其更改为绝对值时,它似乎将其居中到弹出窗口的左边缘。 – antonanton 2009-09-06 14:40:47
更改为绝对位置时,它位于弹出窗口左边缘的原因是因为它的父级(div#容器)也是绝对位置。解决这个问题的一种方法是将弹出的div从容器元素中移出并直接移入body元素。如果您不想将div从div#容器元素中移出,则必须从div#容器中移除绝对位置并将其放在另一个位置 – 2009-09-08 13:32:42