<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>照片墙一多实例演示</title>
<style type="text/css">
body,div,h2,ul,li{margin:0;padding:0;}
body{font:12px/1.5 Arail;}
.box{width:860px;margin:10px auto;background:#eee;border:1px solid #b8b8b8;overflow:hidden}
.title{height:30px;line-height:30px;font-size:14px;padding:0 15px 0 35px;border-bottom:1px solid #b8b8b8;background:#fafafa url(http://js.alixixi.com/img/mm/ico.gif) 5px 50% no-repeat;}
.title span{float:left;}
.title a{float:right;color:#06f;outline:none;}
.title a:hover{color:red;}
.box ul{float:left;padding:0 15px 15px 0;}
.box li{float:left;width:140px;height:105px;padding:6px;background:#fff;border:1px solid #c3c3c3;display:inline;margin:15px 0 0 15px;list-style:none;}
.box li img{float:left;width:140px;height:105px;}
.box li.hig{padding:5px;border:2px dashed #f30;opacity:0.5;filter:alpha(opacity=50);}
</style>
<script type="text/javascript">
//获取ID
var $ = function (id) {return typeof id === "string" "(\\s|^)" + sClass + "($|\\s)"),
 aElement = $$("*", oParent);
 for (i = 0; i < aElement.length; i++)reClass.test(aElement[i].className) && aClass.push(aElement[i]);
 return aClass
};
//获取元素位置
function getPos(obj) {
 var iTop = obj.offsetTop;
 var iLeft = obj.offsetLeft;
 while (obj.offsetParent)
 {
 iTop += obj.offsetParent.offsetTop;
 iLeft += obj.offsetParent.offsetLeft;
 obj = obj.offsetParent;
 }
 return {top:iTop, left:iLeft} 
};
//创建照片墙对象
var PhotoWall = function () {this.initialize.apply(this, arguments)};
PhotoWall.prototype = {
 initialize: function (obj, aData)
 {
 var oThis = this;
 this.oParent = $(obj);
 this.oUl = $$("ul", this.oParent)[0];
 this.oBtn = $$("a", this.oParent)[0];
 this.zIndex = 1;
 this.aPos = [];
 this.aData = aData;
 this.dom = document.documentElement || document.body;
 this.create();
 this.oBtn.onclick = function () {oThis.randomOrder()}
 },
 create: function ()
 {
 var aFrag = document.createDocumentFragment();
 var i = 0;
 for (i = 0; i < this.aData.length; i++)
 {
  var oLi = document.createElement("li");
  var oImg = document.createElement("img");
  oImg.src = this.aData[i];
  oLi.appendChild(oImg);
  aFrag.appendChild(oLi) 
 }
 this.oUl.appendChild(aFrag);
 this.aLi = $$("li", this.oParent);
 this.changeLayout()
 },
 changeLayout: function ()
 {
 var i = 0;
 this.oParent.style.height = this.oParent.offsetHeight - 2 + "px";
 this.aPos.length = 0;
 for (i = 0; i < this.aLi.length; i++) this.aLi[i].style.cssText = ""; 
 for (i = 0; i < this.aLi.length; i++)
 {
  this.aLi[i].index = i;
  this.aLi[i].style.top = getPos(this.aLi[i]).top + "px";
  this.aLi[i].style.left = getPos(this.aLi[i]).left + "px";
  this.aPos.push({left:getPos(this.aLi[i]).left, top:getPos(this.aLi[i]).top})
 }
 for (i = 0; i < this.aLi.length; i++)
 {
  this.aLi[i].style.position = "absolute"; 
  this.aLi[i].style.margin = "0";  
  this.drag(this.aLi[i])
 } 
 },
 drag: function (obj, handle)
 {
 var oThis = this;
 var handle = handle || obj;
 handle.style.cursor = "move";
 handle.onmousedown = function (event)
 {
  var event = event || window.event; 
  var disX = event.clientX - this.offsetLeft;
  var disY = event.clientY - this.offsetTop;
  var oNear = null;
  handle.style.zIndex = oThis.zIndex++;
  
  document.onmousemove = function (event)
  {
  var event = event || window.event;
  var iL = event.clientX - disX;
  var iT = event.clientY - disY;
  var maxL = Math.max(oThis.dom.clientWidth, oThis.dom.scrollWidth) - handle.offsetWidth;
  var maxT = Math.max(oThis.dom.clientHeight, oThis.dom.scrollHeight) - handle.offsetHeight;
  
  iL < 0 && (iL = 0);
  iT < 0 && (iT = 0);
  iL > maxL && (iL = maxL);
  iT > maxT && (iT = maxT);
    
  handle.style.left = iL + "px";
  handle.style.top = iT + "px";
  
  oNear = oThis.findNearest(obj);
  
  for (var i = 0; i < oThis.aLi.length; i++) oThis.aLi[i].className = "";
  
  oNear && (oNear.className = "hig");
  
  return false
  };
  document.onmouseup = function ()
  {
  document.onmousemove = null;
  document.onmouseup = null;
  
  if (oNear)
  {
   handle.index = [handle.index, oNear.index];
   oNear.index = handle.index[0];
   handle.index = handle.index[1];
   oNear.style.zIndex = oThis.zIndex++;
   oThis.doMove(handle, oThis.aPos[handle.index]);
   oThis.doMove(oNear, oThis.aPos[oNear.index]);   
   oNear.className = "";
  }
  else
  {
   oThis.doMove(handle, oThis.aPos[handle.index]) 
  }
  
  handle.releaseCapture && handle.releaseCapture()
  };
  this.setCapture && this.setCapture();
  return false
 };
 },
 doMove: function (obj, iTarget, callback)
 {
 var oThis = this;
 clearInterval(obj.timer);
 obj.timer = setInterval(function ()
 {
  var iCurL = getPos(obj).left;
  var iCurT = getPos(obj).top;
  var iSpeedL = (iTarget.left - iCurL) / 5;
  var iSpeedT = (iTarget.top - iCurT) / 5;
  iSpeedL = iSpeedL > 0 "px";
  obj.style.top = iCurT + iSpeedT + "px" 
  }
 }, 30)
 },
 findNearest: function (obj)
 {
 var aDistance = [];
 var i = 0;
 for (i = 0; i < this.aLi.length; i++) aDistance[i] = this.aLi[i] == obj "box");
 var aData = [];
 var aExample = [];
 var i = 0;
 //生成图片数据
 for (i = 0; i < 20; i++) aData[aData.length] = "http://js.alixixi.com/img/mm/" + i + ".jpg";
 //循环创建多个实例
 for (i = 0; i < aBox.length; i++)
 {
 var oExample = new PhotoWall(aBox[i], aData);
 aExample.push(oExample)
 }
 this.onresize = function ()
 {
 for (var p in aExample) aExample[p].changeLayout() 
 };
 this.onresize()
};
</script>
</head>
<body>
<div class="box">
  <h2 class="title"><span>一堆90后</span><a href="javascript:;" rel="external nofollow" rel="external nofollow" class="order">随机排序</a></h2>
  <ul></ul>
</div>
<div class="box">
  <h2 class="title"><span>一堆90后</span><a href="javascript:;" rel="external nofollow" rel="external nofollow" class="order">随机排序</a></h2>
  <ul></ul>
</div>
</body>
</html>

效果:

原生js实现照片墙效果

以上就是原生js实现照片墙效果的详细内容,更多关于js 照片墙的资料请关注其它相关文章!

标签:
js,照片墙,原生js,照片墙

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com

评论“原生js实现照片墙效果”

暂无“原生js实现照片墙效果”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。