爱易网
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 浏览次数:20200 次
以下是程序代码
<!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滑动门特效
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
联发科享用价钱战 专利难以摆脱高通
成本效益全兼顾 混合云市场前景显现
170号码扎堆上市:手机话费私人定制时代到来?
韩国研制无线充电系统:一次可充40部手机
屌丝程序猿发家机会来了 用大数据来做生意!
诺基亚依托规模效应 猛攻国际市场空白
雷军收买腾讯金山股份:持股比例升至27%
诺基亚称不会更名“微软移动” 5月还将发布新品
科技巨匠体验谷歌眼镜:戴上了就不想摘上去
推荐阅读
更多>
618首日看京东阿里不同策略,鹿死谁手?
打车软件竞争白热化:有冷兵器时代意味
小米年度发布会遭围剿!多款新品难阻品牌危机
同样的背景,罗永浩和雷军到底有什么不同?
公信力消失:马航事件社交媒体传播之痛
广东移动董事长徐龙受调查 圈内对其褒贬不一
微软小冰复活再战移动端:改与米聊、易信和触宝合作
一大波智能路由器正在袭来:小米、360、极路由大PK
诺基亚仍是第二大手机商:功用机有利可图
苹果iWatch或使用量产液态金属 将取代玻璃
Skype周年:与微软联姻到底有没有未来?
谁说黑莓没救?他们在悄悄地深耕企业级市场,在这个领域,苹果三星算什么,他们远远不是黑莓的对手
北京今日实现用支付宝钱包为公交卡充值
CSS控制字符长度和显示长度
猎豹移动上市押海外市场 与小米有合作空间
华为坚持不上市究竟为何?不差钱也不想冒风险
《中国三网融合业务运营管理》研讨报告征订函
郭美美事件推手被抓 “秦火火”拷问网络底线
200美元英特尔Android笔记本行将到来
戴尔新CEO名单曝光:惠普甲骨文高管在列