<!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" ? document.getElementById(id) : id};
//获取tagName
var $$ = function (tagName, oParent) {return (oParent || document).getElementsByTagName(tagName)};
//获取class
var $$$ = function (sClass, oParent) {
var aClass = [],
i = 0,
reClass = new RegExp("(\\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 ? Math.ceil(iSpeedL) : Math.floor(iSpeedL);
iSpeedT = iSpeedT > 0 ? Math.ceil(iSpeedT) : Math.floor(iSpeedT); if (iCurL == iTarget.left && iCurT == iTarget.top)
{
clearInterval(obj.timer);
callback && callback()
}
else
{
obj.style.left = iCurL + iSpeedL + "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 ? Number.MAX_VALUE : this.getDistance(obj, this.aLi[i]); var minNum = Number.MAX_VALUE;
var minIndex = -1;
for (i = 0; i < aDistance.length; i++) aDistance[i] < minNum && (minNum = aDistance[i], minIndex = i); return this.isButt(obj, this.aLi[minIndex]) ? this.aLi[minIndex] : null
},
getDistance: function(obj1, obj2)
{
var a = (obj1.offsetLeft + obj1.offsetWidth / 2) - (obj2.offsetLeft + obj2.offsetWidth / 2);
var b = (obj1.offsetTop + obj1.offsetTop / 2) - (obj2.offsetTop + obj2.offsetTop / 2);
return Math.sqrt(a * a + b * b)
},
isButt: function (obj1, obj2)
{
var l1 = obj1.offsetLeft;
var t1 = obj1.offsetTop;
var r1 = l1 + obj1.offsetWidth;
var b1 = t1 + obj1.offsetHeight; var l2 = obj2.offsetLeft;
var t2 = obj2.offsetTop;
var r2 = l2 + obj2.offsetWidth;
var b2 = t2 + obj2.offsetHeight; return !(r1 < l2 || b1 < t2 || r2 < l1 || b2 < t1)
},
randomOrder: function ()
{
this.aPos.sort(function () {return Math.random() > 0.5 ? 1 : -1});
for (var i = 0; i < this.aLi.length; i++)
{
this.aLi[i].index = i;
this.doMove(this.aLi[i], this.aPos[i])
}
}
};
window.onload = function ()
{
var aBox = $$$("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:;" class="order">随机排序</a></h2>
<ul></ul>
</div>
<div class="box">
<h2 class="title"><span>一堆90后</span><a href="javascript:;" class="order">随机排序</a></h2>
<ul></ul>
</div>
</body>
</html>

效果:

原生JS编写的照片墙效果实例演示特效的更多相关文章

  1. 关于错位动画的练习,原生js编写

    最近在网上看到一个关于错位动画的文章,感觉非常有趣,便自己练习了一下,文章连接:http://www.w3cplus.com/animation/staggering-animations.html ...

  2. 原生JS封装简单动画效果

    原生JS封装简单动画效果 一致使用各种插件,有时候对原生JS陌生了起来,所以决定封装一个简单动画效果,熟悉JS原生代码 function animate(obj, target,num){ if(ob ...

  3. 面向对象原生js幻灯片代淡出效果

    面向对象原生js幻灯片代淡出效果 下面是代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" & ...

  4. 原生js实现的放大镜效果

    这是我用原生js写的放大镜效果,与各种各样的框架技术相比,我喜欢使用原生的js,在这里,想和大家一起谈谈原生和框架技术的理解与个人喜好. <!DOCTYPE HTML><html&g ...

  5. jq与原生js实现收起展开效果

    jq与原生js实现收起展开效果 (jq需自己加载) <!DOCTYPE html> <html> <head> <meta charset="UTF ...

  6. 原生JS实现淡入淡出效果(fadeIn/fadeOut/fadeTo)

    淡入淡出效果,在日常项目中经常用到,可惜原生JS没有类似的方法,而有时小的页面并不值得引入一个jQuery库,所以就自己写了一个,已封装, 有用得着的朋友, 可以直接使用. 代码中另附有一个设置元素透 ...

  7. 原生js编写的安全色拾色器

    <html > <head> <meta http-equiv="Content-Type" content="text/html; cha ...

  8. 原生JS编写getByClass、addClass、removeClass、hasClass

    前言: 年后换了工作,在现在的公司写交互主要使用JS原生:刚刚入门前端的时候写交互一直用的原生JS,虽然用的不怎么样.后来去之前的公司之后,leader主张把jQuery用好,JS原生自然就熟练了:一 ...

  9. 原生JS轮播-各种效果的极简实现(二)面向对象版本的实现和优化

    之前写了一篇原生JS轮播,不过是非面向对象的,并且也没有添加上自动轮播.这里来写一下如何优化和进阶. 这里简单地介绍一下之前的代码,这是html结构 <body> <div clas ...

随机推荐

  1. 读入一个c程序,并按字母表顺序分组打印变量名,每组前N个字符相同(TCPL 练习6-2)

    在建立结构tnode的过程中,我们没有预设门槛.这道题目就设置了门槛,必须根据前N个字符来进行分组,于是排除了长度小于N的变量,以便减轻负担. 因为要求对变量名分组打印,组别理所应当地应该按照至少是升 ...

  2. 初入liunx的一些基本的知识

    本系列的博客来自于:http://www.92csz.com/study/linux/ 在此,感谢原作者提供的入门知识 这个系列的博客的目的在于将比较常用的liunx命令从作者的文章中摘录下来,供自己 ...

  3. [.NET领域驱动设计实战系列]专题九:DDD案例:网上书店AOP和站点地图的实现

    一.引言 在前面一专题介绍到,要让缓存生效还需要实现对AOP(面向切面编程)的支持.所以本专题将介绍了网上书店案例中AOP的实现.关于AOP的概念,大家可以参考文章:http://www.cnblog ...

  4. IO完成端口

    从MSDN中翻译了IO完成端口的文章,不得不说翻译的很烂,英语需要继续提高啊... 在一个多处理器系统上,IO完成端口提供一个非常高效的线程模型来处理多个异步IO请求.当一个进程创建了一个IO完成端口 ...

  5. Unity3D热更新全书-脚本(二) 两级分化

    上篇明确了我们探讨的脚本是什么:是写在文本文件里面的代码,可以作为资源加载,取得字符串再执行. 可是为什么世界上会有那么多的脚本?而其使用方法完全看起来不一样呢?这是因为每种脚本都有自己的定位,在不同 ...

  6. [51单片机] 以PWM控制直流电机为例建一个简单的51工程框架

    目录 1)功能概述 2)引脚连接 3)框架介绍 4)模块说明 5)复用规则 6)工程链接 1)功能概述 名称:独立按键控制直流电机调速 内容:对应的电机接口需用杜邦线连接到uln2003电机控制端; ...

  7. [译]C++, Java和C#的编译过程解析

    1.1.1 摘要 我们知道计算机不能直接理解高级语言,它只能理解机器语言,所以我们必须要把高级语言翻译成机器语言,这样计算机才能执行高级语言编写的程序,在接下来的博文中,我们将介绍非托管和托管语音的编 ...

  8. Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制

    在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需 ...

  9. EF架构~基于EF数据层的实现

    回到目录 之前写过关于实现一个完整的EF架构的文章,文章的阅读量也是满大的,自己很欣慰,但是,那篇文章是我2011年写的,所以,技术有些不成熟,所以今天把我的2014年写的EF底层架构公开一下,这个架 ...

  10. lua的io操作文档

    2014-09-16~15:26:35 I/O库提供两种不同的方式进行文件处理1.io表调用方式:使用io表,io.open将返回指定文件的描述,并且所有的操作将围绕这个文件描述 io表同样提供三种预 ...