爱易网
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 浏览次数:20211 次
以下是程序代码
<!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=gb2312" /> <title>图片滑动展示效果</title> <script type="text/javascript"> var $$ = function (id) { return "string" == typeof id ? document.getElementById(id) : id; }; function Event(e){ var oEvent = document.all ? window.event : e; if (document.all) { if(oEvent.type == "mouseout") { oEvent.relatedTarget = oEvent.toElement; }else if(oEvent.type == "mouseover") { oEvent.relatedTarget = oEvent.fromElement; } } return oEvent; } function addEventHandler(oTarget, sEventType, fnHandler) { if (oTarget.addEventListener) { oTarget.addEventListener(sEventType, fnHandler, false); } else if (oTarget.attachEvent) { oTarget.attachEvent("on" + sEventType, fnHandler); } else { oTarget["on" + sEventType] = fnHandler; } }; var Class = { create: function() { return function() { this.initialize.apply(this, arguments); } } } Object.extend = function(destination, source) { for (var property in source) { destination[property] = source[property]; } return destination; } var GlideView = Class.create(); GlideView.prototype = { //容器对象 容器宽度 展示标签 展示宽度 initialize: function(obj, iHeight, sTag, iMaxHeight, options) { var oContainer = $$(obj), oThis=this, len = 0; this.SetOptions(options); this.Step = Math.abs(this.options.Step); this.Time = Math.abs(this.options.Time); this._list = oContainer.getElementsByTagName(sTag); len = this._list.length; this._count = len; this._height = parseInt(iHeight / len); this._height_max = parseInt(iMaxHeight); this._height_min = parseInt((iHeight - this._height_max) / (len - 1)); this._timer = null; this.Each(function(oList, oText, i){ oList._target = this._height * i;//自定义一个属性放目标left oList.style.top = oList._target + "px"; oList.style.position = "absolute"; addEventHandler(oList, "mouseover", function(){ oThis.Set.call(oThis, i); }); }) //容器样式设置 oContainer.style.height = iHeight + "px"; oContainer.style.overflow = "hidden"; oContainer.style.position = "relative"; //移出容器时返回默认状态 addEventHandler(oContainer, "mouseout", function(e){ //变通防止执行oList的mouseout var o = Event(e).relatedTarget; if (oContainer.contains ? !oContainer.contains(o) : oContainer != o && !(oContainer.compareDocumentPosition(o) & 16)) oThis.Set.call(oThis, -1); }) }, //设置默认属性 SetOptions: function(options) { this.options = {//默认值 Step: 20,//滑动变化率 Time: 3,//滑动延时 TextTag: "",//说明容器tag TextHeight: 0//说明容器高度 }; Object.extend(this.options, options || {}); }, //相关设置 Set: function(index) { if (index < 0) { //鼠标移出容器返回默认状态 this.Each(function(oList, oText, i){ oList._target = this._height * i; if(oText){ oText._target = this._height_text; } }) } else { //鼠标移到某个滑动对象上 this.Each(function(oList, oText, i){ oList._target = (i <= index) ? this._height_min * i : this._height_min * (i - 1) + this._height_max; if(oText){ oText._target = (i == index) ? 0 : this._height_text; } }) } this.Move(); }, //移动 Move: function() { clearTimeout(this._timer); var bFinish = true;//是否全部到达目标地址 this.Each(function(oList, oText, i){ var iNow = parseInt(oList.style.top), iStep = this.GetStep(oList._target, iNow); if (iStep != 0) { bFinish = false; oList.style.top = (iNow + iStep) + "px"; } }) //未到达目标
上一篇:狡猾的按钮特效
下一篇:简单小巧的JavaScript Tab滑动门特效
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
第二梯队也PK:当1号店“遇上”京东手机节
传谷歌开发者大会发布Android 4.3 并非5.0版本
马云的SNS之梦有了新目标 收购“微博”
HDS发布《2013中国CIO洞察白皮书》
央行暂停二维码支付及虚拟信用卡 支付宝微信不知情
三星手机在国内陷入困境:华为中兴小米紧追
地图导航骤起杀机 百度高德重新定义商业模式
MIUI,有了它小米就无惧对手
工商总局开查电商“七日退货”
推荐阅读
更多>
埃里克杰克森:阿里IPO估值至少1500亿美元
苹果MacBook Air劣势渐显 或推新产品改变命运
云储存有多远:跨过数据安全问题即可到达
苹果大中华区业绩回暖 中移动贡献或低于预期
估值增长9.8% 阿里IPO前市值达2450亿美元
一大波智能路由器正在袭来:小米、360、极路由大PK
乐视今日临时停牌 受广电酝酿新规消息影响
支付宝服务窗后台首曝光 开放用户消费数据
苹果优势逐渐丧失 传即将推出廉价iPhone
看蜗牛如何放水养鱼,盘活生态系统
携程整合去哪儿陷入僵局 欲联手老对手艺龙
北京电信推“0月租卡”,同网通话免费
虚拟运营商温度有多高?降温OR升温内外有别
【晚报】女子泰国游晒10照片 流量费2000
华为坚持不上市究竟为何?不差钱也不想冒风险
王建宙解构OTT效劳 中移动重塑飞信平台
苹果股价突破100美元大关:投资者看好iPhone 6
佳能利润大跌三成 智能终端倒逼相机厂商转型
微软提示XP只剩365天寿命:用户被绑架?
京东封杀财付通:终极目标是电商生态圈