爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
原生JS编写的照片墙效果实例演示特效
原生JS编写的照片墙效果实例演示特效
日期:2014-05-18 浏览次数:20323 次
以下是程序代码
<!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.aiyiweb.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 = "
上一篇:狡猾的按钮特效
下一篇:面向对象的无缝上下滚动图片特效代码,带上下箭头指示
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
三大运营商合建铁塔公司真相:未涉及电信业重组
特斯拉技术专利开放,要革自己的命?
虚拟运营商前路迷茫 业界建议发力车联网
曝阿里巴巴一怀孕员工过劳死 加班情况引争议
迅雷向美SEC提交IPO招股书:拟最多筹资1亿美元
从旗下三大业务BG发展看华为的过去现在和未来
微软小冰复活再战移动端:改与米聊、易信和触宝合作
传360周鸿祎曾试图阻止百度收购91无线
诺基亚培育低端机市场 迂回战术要挟中华酷联
推荐阅读
更多>
纸媒深探版权蓝海抗衡互联网的时机到来了
微信今天大面积崩溃 腾讯:因光缆施工被挖断
马斯克的特斯拉能否保持好势头
马云:银行若放开存款利率 余额宝死了也光荣
2018年阿里云双11活动如何参加?1折优惠大攻略
传苹果已告知鸿海:两款新iPhone下月发货
在线音乐出现“小米公司”不是没有可能
顺丰O2O便利店将正式启动:涉及金融服务
全球最具“颠覆性”特质的公司排行榜TOP25
英特尔承认,联想最新K系列智能手机放弃英特尔处理器
移动联通回应税率改革:短期内收入利润将大减
易迅大众点评缩水执行“七天后悔权”被约谈
历史惊人相似:如今的库克 曾经的鲍尔默
挂号网高管团体离任 或因投资人失掉决计
iPhone 6将于10月17日内地上市:售5288元起
小米2S试水高端化 纯“性价比”玩法已成过去式
迅雷再次在美提交IPO申请
马云寄厚望于物流 “菜鸟”行情暂难持续
微软张亚勤趋势判断:未来三十年属于物理化互联网
靠价格战赚取资费套餐利润差,虚拟运营商必死无疑