JS+CSS实现DIV层的展开、收缩效果


Posted in Javascript onJanuary 28, 2016

本文为大家分享的第一个实例:JS控制DIV层的展开、收缩效果。

<html>
<head>
<title>CSS+JS实现一个DIV层的展开/折叠效果</title>
<style>
* { margin:0; padding:0;}
body { text-align:center; font:75% Verdana, Arial, Helvetica, sans-serif;}
h1 { font:125% Arial, Helvetica, sans-serif; text-align:left; font-weight:bolder; background:#555; padding:3px; display:block; color:#99CC00}
.class1 { width:40%; background:#CCCCCC; position:relative; margin:0 auto; padding:5px;}
span { position:absolute; right:10px; top:8px; cursor:pointer; color:yellow;}
p { text-align:left; line-height:20px; background:#555; padding:3px; margin-top:5px; color:#99CC00}
#class1content { height:256px;overflow:hidden}
</style>
<script>
function $(element){
return element = document.getElementById(element);
}
function $D(){
var d=$('class1content');
var h=d.offsetHeight;
var maxh=300;
function dmove(){
h+=50; //层展开速度
if(h>=maxh){
d.style.height='300px';
clearInterval(iIntervalId);
}else{
d.style.display='block';
d.style.height=h+'px';
}
}
iIntervalId=setInterval(dmove,2);
}
function $D2(){
var d=$('class1content');
var h=d.offsetHeight;
var maxh=300;
function dmove(){
h-=50;//层收缩速度
if(h<=0){
d.style.display='none';
clearInterval(iIntervalId);
}else{
d.style.height=h+'px';
}
}
iIntervalId=setInterval(dmove,2);
}
function $use(){
var d=$('class1content');
var sb=$('stateBut');
if(d.style.display=='none'){
$D();
sb.innerHTML='收缩';
}else{
$D2();
sb.innerHTML='展开';
}
}
</script>
</head>
<body>
<div class="class1">
<span id="stateBut" onclick="$use()">收缩</span>
<p id="class1content">三水点靠木。
</p>
</div>
</body>

效果图:

JS+CSS实现DIV层的展开、收缩效果

第二个实例:js 控制展开折叠

<html>
<head>
  <meta http-equiv="Content-Type" content="text/html;charset=gb2312">
  <title>Title</title>
</head>
<body>
<!-- js 控制 展开 隐藏div -->
<img src="image/down.png" onclick="test(this)">  <!--this 指 img 对象 -->

<div id="div2" style="border:1px solid #ccc; width:300px; height:200px; display: block;">
  (1)每个HTML标记都有事件句柄属性。onClick是HTML标记属性,不分大小写。
  (2)HTML标记对应的元素对象也具有事件句柄属性,这个属性必须全小写,因JS区分大小写
</div>
</body>
</html>
<script type="text/javascript">
function test(obj){

  var div1=document.getElementById("div2");
  if(div1.style.display=="block"){
    div1.style.display="none";
    obj.src="image/up.png";
  }else{
    div1.style.display="block";
    obj.src="image/down.png";
  }
}
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
Jquery AJAX 用于计算点击率(统计)
Jun 30 Javascript
JS继承--原型链继承和类式继承
Apr 08 Javascript
Ajax异步提交表单数据的说明及方法实例
Jun 22 Javascript
jquery实现更改表格行顺序示例
Apr 30 Javascript
jquery实现勾选复选框触发事件给input赋值
Feb 01 Javascript
基于jQuery实现Div窗口震动特效代码-代码简单
Aug 28 Javascript
Bootstrap基本组件学习笔记之分页(12)
Dec 08 Javascript
利用原生JS与jQuery实现数字线性变化的动画
Feb 24 Javascript
深入理解Webpack 中路径的配置
Jun 17 Javascript
JS实现为动态创建的元素添加事件操作示例
Mar 17 Javascript
bootstrap中日历范围选择插件daterangepicker的使用详解
Apr 17 Javascript
微信小程序和H5页面间相互跳转代码实例
Sep 19 Javascript
js+canvas绘制五角星的方法
Jan 28 #Javascript
js+html5实现的自由落体运动效果代码
Jan 28 #Javascript
js判断上传文件后缀名是否合法
Jan 28 #Javascript
Angular中$compile源码分析
Jan 28 #Javascript
实例讲解JS中setTimeout()的用法
Jan 28 #Javascript
jQuery+canvas实现的球体平抛及颜色动态变换效果
Jan 28 #Javascript
jQuery+canvas实现简单的球体斜抛及颜色动态变换效果
Jan 28 #Javascript
You might like
Sony CFR 320 修复改造
2020/03/14 无线电
PHP中文分词的简单实现代码分享
2011/07/17 PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
2015/07/31 PHP
基于php流程控制语句和循环控制语句(讲解)
2017/10/23 PHP
PHP pthreads v3下worker和pool的使用方法示例
2020/02/21 PHP
改变checkbox默认选中状态及取值的实现代码
2016/05/26 Javascript
jQuery简单注册和禁用全局事件的方法
2016/07/25 Javascript
Node.js Sequelize如何实现数据库的读写分离
2016/10/23 Javascript
基于Angularjs+mybatis实现二级评论系统(仿简书)
2017/02/13 Javascript
vue.js-div滚动条隐藏但有滚动效果的实现方法
2018/03/03 Javascript
js实现点赞按钮功能的实例代码
2020/03/06 Javascript
解决Vue使用bus总线时,第一次路由跳转时数据没成功传递问题
2020/07/28 Javascript
微信小程序实现modal弹出框遮罩层组件(可带文本框)
2020/12/20 Javascript
[06:09]辉夜杯主赛事开幕式
2015/12/25 DOTA
[01:29:46]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第二局
2016/02/27 DOTA
Python入门篇之面向对象
2014/10/20 Python
利用Python爬取可用的代理IP
2016/08/18 Python
【python】matplotlib动态显示详解
2019/04/11 Python
PyQt5组件读取参数的实例
2019/06/25 Python
在Django下创建项目以及设置settings.py教程
2019/12/03 Python
用Python去除图像的黑色或白色背景实例
2019/12/12 Python
TensorFlow加载模型时出错的解决方式
2020/02/06 Python
如何基于matlab相机标定导出xml文件
2020/11/02 Python
python 制作简单的音乐播放器
2020/11/25 Python
pytorch下的unsqueeze和squeeze的用法说明
2021/02/06 Python
CSS+jQuery+PHP+MySQL实现的在线答题功能
2015/04/25 HTML / CSS
CSS3 实现的加载动画
2020/12/07 HTML / CSS
使用phonegap检测网络状态的方法
2017/03/30 HTML / CSS
使用useBean标志初始化BEAN时如何接受初始化参数
2012/02/11 面试题
J2EE的优越性主要表现在哪些方面
2016/03/28 面试题
工作人员思想汇报
2014/01/09 职场文书
幼儿园大班区域活动总结
2014/07/09 职场文书
纪律教育学习月活动总结
2014/08/27 职场文书
暑期家教宣传单
2015/07/14 职场文书
2019各种保证书范文
2019/06/24 职场文书
SQL基础查询和LINQ集成化查询
2022/01/18 MySQL