原生js实现照片墙效果


Posted in Javascript onOctober 13, 2020
<!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:;" 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 照片墙的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
提高 DHTML 页面性能
Dec 25 Javascript
javascript下4个跨浏览器必备的函数
Mar 07 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
Nov 14 Javascript
js实现Select列表内容自动滚动效果代码
Aug 20 Javascript
一篇文章掌握RequireJS常用知识
Jan 26 Javascript
javascript实现一个简单的弹出窗
Feb 22 Javascript
javascript 解决浏览器不支持的问题
Sep 24 Javascript
js读取json文件片段中的数据实例
Mar 09 Javascript
JavaScript中Array方法你该知道的正确打开方法
Sep 11 Javascript
微信小程序实现两边小中间大的轮播效果的示例代码
Dec 07 Javascript
vue-amap根据地址回显地图并mark的操作
Nov 03 Javascript
JavaScript 中for/of,for/in 的详细介绍
Nov 17 Javascript
js轮播图之旋转木马效果
Oct 13 #Javascript
Vue中正确使用Element-UI组件的方法实例
Oct 13 #Javascript
JavaScript数组常用的增删改查与其他属性详解
Oct 13 #Javascript
JS将指定的某个字符全部转换为其他字符实例代码
Oct 13 #Javascript
JavaScript实现拖动对话框效果的实现代码
Oct 12 #Javascript
react的hooks的用法详解
Oct 12 #Javascript
微信小游戏中three.js离屏画布的示例代码
Oct 12 #Javascript
You might like
如何使用PHP实现javascript的escape和unescape函数
2013/06/29 PHP
PHP对象克隆clone用法示例
2016/09/28 PHP
在网页中屏蔽快捷键
2006/09/06 Javascript
Jquery颜色选择器ColorPicker实现代码
2012/11/14 Javascript
jquery实现图片等比例缩放以及max-width在ie中不兼容解决
2013/03/21 Javascript
利用JavaScript实现新闻滚动效果(实例代码)
2013/11/27 Javascript
js 判断js函数、变量是否存在的简单示例代码
2014/03/04 Javascript
JavaScript对Cookie进行读写操作实例
2015/07/25 Javascript
js实现仿京东2级菜单效果(带延时功能)
2015/08/27 Javascript
基于javascript实现图片预加载
2016/01/05 Javascript
JavaScript+html5 canvas实现图片破碎重组动画特效
2016/02/22 Javascript
[原创]jQuery常用的4种加载方式分析
2016/07/25 Javascript
knockoutjs动态加载外部的file作为component中的template数据源的实现方法
2016/09/01 Javascript
完美解决IE9浏览器出现的对象未定义问题
2016/09/29 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
Vue表单验证插件Vue Validator使用方法详解
2017/04/07 Javascript
jquery append与appendTo方法比较
2017/05/24 jQuery
js自定义Tab选项卡效果
2017/06/05 Javascript
Vue项目中quill-editor带样式编辑器的使用方法
2017/08/08 Javascript
基于Node.js模板引擎教程-jade速学与实战1
2017/09/17 Javascript
Vue2 配置 Axios api 接口调用文件的方法
2017/11/13 Javascript
Vue代码分割懒加载的实现方法
2017/11/23 Javascript
vue-star评星组件开发实例
2018/03/01 Javascript
Python中super函数的用法
2017/11/17 Python
python如何导出微信公众号文章方法详解
2020/08/31 Python
用60行代码实现Python自动抢微信红包
2021/02/04 Python
求职意向书范文
2014/04/01 职场文书
工作疏忽、懈怠的检讨书
2014/09/11 职场文书
机关干部个人对照检查材料思想汇报
2014/09/28 职场文书
财务工作失误检讨书
2015/02/19 职场文书
巴黎圣母院读书笔记
2015/06/26 职场文书
教师信息技术学习心得体会
2016/01/21 职场文书
用Python实现一个打字速度测试工具来测试你的手速
2021/05/28 Python
一篇文章告诉你如何实现Vue前端分页和后端分页
2022/02/18 Vue.js
MySQL中IO问题的深入分析与优化
2022/04/02 MySQL
Spring Boot 实现 WebSocket
2022/04/30 Java/Android