首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jquery元素定位等

Jquery元素定位等
EN

Stack Overflow用户
提问于 2010-12-01 22:51:05
回答 1查看 157关注 0票数 0

嘿,伙计们,我通常对编辑很在行,但这次我想尝试一下Jquery的新功能。我正在尝试创建一个"3D“卡片页面(类似于这个:http://activeden.net/item/xml-3d-video-showcase/83740?clickthrough_id=&redirect_back=true&ref=45),但是我无法定位元素,并且我认为我的代码都错了。

下面是JS:

代码语言:javascript
复制
$(document).ready(function() { //perform actions when DOM is ready
 var z = 0; //for setting the initial z-index's
    var inAnimation = false; //flag for testing if we are in a animation
    var imgLoaded = 0; //for checking if all images are loaded

 $('.img').each(function() {
  z++; 
  $(this).css('z-index', z);
  imgLoaded++;
 });

function swapFirstLast(isFirst) {
  if(inAnimation) return false; //if already swapping pictures just return
  else inAnimation = true; //set the flag that we process a image

  var processZindex, direction, newZindex, inDeCrease; //change for previous or next image
  if(isFirst) { 
      processZindex = z; newZindex = 1; inDeCrease = 1; 
     } else { 
      processZindex = 1; newZindex = z; inDeCrease = -1; 
     } //set variables for "next" and "previous" action

  $('.img').each(function() { //process each image
   if($(this).css('z-index') == processZindex) { //if its the image we need to process
    $(this).animate({ opacity: 0,top: $(this).height() + 'px' }, 'slow', function() { 
     $(this).css('z-index', newZindex) //set new z-index
      .animate({top : '0' }, 'slow', function() {
       inAnimation = false; //reset the flag
       $(this).animate({ opacity: 1 }, 500);
      });
    });
   } else { //not the image we need to process, only in/de-crease z-index
    $(this).animate({top : '0' }, 'slow', function() { //make sure to wait swapping the z-index whe
     $(this).css('z-index', parseInt($(this).css('z-index')) + inDeCrease); //in/de-crease the z-index by one
    });
   }
  });
 return false; //don't follow the clicked link
 }

 $('#next a').click(function() {
  return swapFirstLast(true); //swap first image to last position
 });

 $('#prev a').click(function() {
  return swapFirstLast(false); //swap last image to first position
 });

});

下面是HTML:

代码语言:javascript
复制
<html>
<head>
<style type="text/css">
ul { list-style: none;
 margin: 200px;}

#pictures { position: relative; height: 408px;}

.img {
 position: absolute;
 top: 10;
 left: 0;
 padding: 10px;
 background: #eee;
 border: 1px solid #fff;
 -webkit-transform: translate(0px, 0px) skew(0deg, 5deg);
}
.desc {
 max-height: 30px;
 text-align: center;
 padding: 10px 10px 0 10px;
}
li {
 border: 5px solid #c4c8cc;
 -moz-box-shadow: 3px 3px 10px #888;
 -webkit-box-shadow: 3px 3px 10px #888;
 padding: 200px;
}
</style>
</head>
</html>

<div id="gallery"> 

 <ul id="pictures"> 
  <li class="img">
   <div class="desc">Hello World</div>
  </li>
  <li class="img">
   <div class="desc">Hello World</div>
  </li>
 </ul> 
</div> 

很抱歉弄得一团糟,但我很着急-所有的帮助都非常感谢:D

EN

回答 1

Stack Overflow用户

发布于 2010-12-05 06:13:58

@keiran,你真的很亲近。我把你的内容放到了jsbin上。不是很确定你希望最后的东西看起来是什么样子。这看起来是可行的。

http://jsbin.com/awule4/5/edit#preview

希望这能有所帮助。

鲍勃

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4325567

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档