jQuery背景墙聚光灯效果代码

所属分类:媒体-图片展示

 6164  34  查看评论 (2)
jQuery背景墙聚光灯效果代码 ie兼容6

感谢X.z提供

按一下顺序操作!

引入jQuery

<script src="http://libs.baidu.com/jquery/1.6.4/jquery.min.js"></script>

jQuery插件

 <script type="text/javascript" charset="utf-8">
	$(window).load(function() {
		var spotlight = {
			// the opacity of the "transparent" images - change it if you like
			opacity: 0.2,
			/*the vars bellow are for width and height of the images so we can make 
    the <li> same size */
			imgWidth: $('.spotlightWrapper ul li').find('img').width(),
			imgHeight: $('.spotlightWrapper ul li').find('img').height()

		};

		//set the width and height of the list items same as the images
		$('.spotlightWrapper ul li').css({
			'width': spotlight.imgWidth,
			'height': spotlight.imgHeight
		});

		//when mouse over the list item...
		$('.spotlightWrapper ul li').hover(function() {

			//...find the image inside of it and add active class to it and change opacity to 1 (no transparency)
			$(this).find('img').addClass('active').css({
				'opacity': 1
			});

			//get the other list items and change the opacity of the images inside it to the one we have set in the spotlight array 
			$(this).siblings('li').find('img').css({
				'opacity': spotlight.opacity
			});

			//when mouse leave...
		},
		function() {

			//... find the image inside of the list item we just left and remove the active class
			$(this).find('img').removeClass('active');

		});

		//when mouse leaves the unordered list...
		$('.spotlightWrapper ul').bind('mouseleave',
		function() {
			//find the images and change the opacity to 1 (fully visible)
			$(this).find('img').css('opacity', 1);
		});

	});
</script>

CSS样式

<style type="text/css" media="screen">
  body { background:black; color:white; font-family: 'georgia' } /* not important */
  .spotlightWrapper ul { 
   list-style-type: none; /* remove the default style for list items (the circles) */ 
   margin:0px; /* remove default margin */
   padding:0px; /* remove default padding */
  }
  .spotlightWrapper ul li { 
   float:left; /* important: left float */
   position:relative; /* so we can use top and left positioning */
  }
  .spotlightWrapper ul li a img { 
   width:200px; /* you don't need this, i just rescaled the images they are bigger then i want them to be ' */
   position:relative; /* so we can use top and left positioning */
   border:none; /* remove the default blue border */
  }
  .spotlightWrapper ul li a img.active {
   border:4px solid white; /* choose whatever you like */
   z-index:1; /* show it on top of the other images (they have z-index 0) */
   left: -4px; /* same as border width but negative */
   top: -4px; /* same as border width but negative */
  }
  .clear { clear:both; } /* to clear the float after the last item */
 </style>

HTML

<div class='spotlightWrapper'>
  <ul>
   <li><a href='#'><img src='images/1.jpg' /></a></li>
  </ul>
</div>

相关插件-图片展示

jQuery视差插件ImageScroll

这个插件是非常简单的使用有一些选项的修改。它利用CSS3动画,支持落回顶部和老的浏览器。
  图片展示
 11544  46

jquery 3d全景效果插件Theta Viewer

3d全景效果插件Theta Viewer,拖动可全方位查看全景图各个方位
  图片展示
 6599  65

jQuery图片展示插件 Portfolio

jQuery Portfolio插件有点类似google图片搜索结果点击后展示预览效果
  图片展示
 13214  27

jQuery原始图片对比插件

这是一款很实用的jQuery图片插件,它可以帮助你实现原图和经过处理的图片进行对比,这款jQuery插件一共有3中对比模式,主要是拖动中间的分割线来进行两张图片的细节对比。
  图片展示
 5258  30

讨论这个项目(2)回答他人问题或分享插件使用方法奖励jQ币

    hacker 0
    2014/11/6 14:04:18
    这个得看需求了,如果是不要求支持低版本浏览器,css3当然更好的 回复
    Mr ●黄 0
    2014/11/6 2:12:37
    这个不需要jquery去实现吧,css就可以了,结合css3加点过度效果,蛮好的。 回复
取消回复