js实现div层缓慢收缩与展开的方法


Posted in Javascript onMay 11, 2015

本文实例讲述了js实现div层缓慢收缩与展开的方法。分享给大家供大家参考。具体分析如下:

这是一个层伸缩与展开的特效代码,带有点动画效果,缓慢展开,DIV+JS联合打造,看上去还不错。不受内容约束,收缩与展开的速度是可以控制的,高度、循环时间也可以改。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>层收缩</title>
<script type="text/javascript">
var mh = 30;//高度
var step = 1;//每次变化的量
var ms = 10;//循环时间
function toggle(o){
 if (!o.tid)o.tid = "_" + Math.random() * 100;
 if (!window.toggler)window.toggler = {};
 if (!window.toggler[o.tid]){
  window.toggler[o.tid]={
   obj:o,
   maxHeight:o.offsetHeight,
   minHeight:mh,
   timer:null,
   action:1
  };
 }
 o.style.height = o.offsetHeight + "px";
 if (window.toggler[o.tid].timer)clearTimeout(window.toggler[o.tid].timer);
 window.toggler[o.tid].action *= -1;
 window.toggler[o.tid].timer = setTimeout("anim('"+o.tid+"')",ms );
}
function anim(id){
 var t = window.toggler[id];
 var o = window.toggler[id].obj;
 if (t.action < 0){
  if (o.offsetHeight <= t.minHeight){
   clearTimeout(t.timer);
   return;
  }
 }
 else{
  if (o.offsetHeight >= t.maxHeight){
   clearTimeout(t.timer);
   return;
  }
 }
 o.style.height = (parseInt(o.style.height, 10) + t.action * step) + "px";
 window.toggler[id].timer = setTimeout("anim('"+id+"')",ms );
}
</script>
<style type="text/css">
div.xx{
 border:solid 1px;overflow:hidden;
}
div.xx h5{
 border:solid 1px;border-width:0 0 1px;
 padding:0;margin:0;height:28px;
 line-height:30px;cursor:pointer;
 background:#eee;
}
</style>
</head>
<body>
<div class="xx"><h5 onclick="toggle(this.parentNode)">点击此处层伸缩</h5>
<p>Tomat6.0的配置视频教程,AVI电影格式,相当清淅了,比起图文版的教程更贴切,
不会配置Tomcat的网友,你可不要错过哦,由于视频抓图挺麻烦的,
试了多次还是抓了一个不太清淅的,大家将就吧。</p>
</div>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
在chrome中window.onload事件的一些问题
Mar 01 Javascript
JavaScript游戏之优化篇
Nov 08 Javascript
jsp网页搜索结果中实现选中一行使其高亮
Feb 17 Javascript
通过$(this)使用jQuery包装后的方法或属性
May 18 Javascript
jQuery trigger()方法用法介绍
Jan 13 Javascript
JavaScript判断字符长度、数字、Email、电话等常用判断函数分享
Apr 01 Javascript
JavaScript实现列表分页功能特效
May 15 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
Apr 19 Javascript
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Dec 14 Javascript
js原生Ajax的封装和原理详解
Mar 11 Javascript
详解Vue-Cli 异步加载数据的一些注意点
Aug 12 Javascript
JS实现“全选”和&quot;全不选&quot;功能代码实例
Feb 06 Javascript
JS实现定时自动关闭DIV层提示框的方法
May 11 #Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 #Javascript
JavaScript实现表格点击排序的方法
May 11 #Javascript
JavaScript点击按钮后弹出透明浮动层的方法
May 11 #Javascript
js实现鼠标移到链接文字弹出一个提示层的方法
May 11 #Javascript
js光标定位文本框回车表单提交问题的解决方法
May 11 #Javascript
jQuery子窗体取得父窗体元素的方法
May 11 #Javascript
You might like
php实现构建排除当前元素的乘积数组方法
2018/10/06 PHP
javascript showModalDialog 多层模态窗口实现页面提交及刷新的代码
2009/11/28 Javascript
关于Mozilla浏览器不支持innerText的解决办法
2011/01/01 Javascript
30个精美的jQuery幻灯片效果插件和教程
2011/08/23 Javascript
node.js中的http.response.end方法使用说明
2014/12/14 Javascript
jQuery中replaceWith()方法用法实例
2014/12/25 Javascript
Jquery实现遮罩层的方法
2015/06/08 Javascript
JavaScript数组各种常见用法实例分析
2015/08/04 Javascript
js如何打印object对象
2015/10/16 Javascript
jQuery html表格排序插件tablesorter使用方法详解
2017/02/10 Javascript
jQuery的$.extend 浅拷贝与深拷贝
2017/03/08 Javascript
JavaScript数据结构中串的表示与应用实例
2017/04/12 Javascript
Javascript实现一个简单的输入关键字添加标签效果实例
2017/06/01 Javascript
JavaScript hasOwnProperty() 函数实例详解
2017/08/04 Javascript
vue select二级联动第二级默认选中第一个option值的实例
2018/01/10 Javascript
微信小程序页面间传值与页面取值操作实例分析
2019/04/30 Javascript
基于layui的table插件进行复选框联动功能的实现方法
2019/09/19 Javascript
vue 查看dist文件里的结构(多种方式)
2020/01/17 Javascript
Python读写Redis数据库操作示例
2014/03/18 Python
python基于multiprocessing的多进程创建方法
2015/06/04 Python
python字典键值对的添加和遍历方法
2016/09/11 Python
Python中str.format()详解
2017/03/12 Python
Python视频爬虫实现下载头条视频功能示例
2018/05/07 Python
Python自定义函数计算给定日期是该年第几天的方法示例
2019/05/30 Python
scrapy数据存储在mysql数据库的两种方式(同步和异步)
2020/02/18 Python
Pycharm中import torch报错的快速解决方法
2020/03/05 Python
python性能测试工具locust的使用
2020/12/28 Python
Marriott国际:万豪国际酒店查询预订
2017/09/25 全球购物
介绍一下OSI七层模型
2012/07/03 面试题
大学生学业生涯规划
2014/01/05 职场文书
部队党性分析材料
2014/02/16 职场文书
大学军训感言200字
2014/02/26 职场文书
服务承诺书格式
2014/05/21 职场文书
初中学习计划书范文
2014/09/15 职场文书
2014年小学语文工作总结
2014/12/20 职场文书
Vue如何清空对象
2022/03/03 Vue.js