vue.js 实现点击展开收起动画效果


Posted in Javascript onJuly 07, 2018

最近公司项目加了个页面,其中要求是这样的,点击对应列表,展开和收起,其实就是显示和隐藏内容部分;说来惭愧,我花了半天时间才搞出来(自黑一下~),接下来分享给大家,先上效果图:

vue.js 实现点击展开收起动画效果

vue页面:

<template>
  <div class="dealRecord-wrap">
    <div class="title-contant" v-for="(item,index) in items " >

      <div class="title" @click="showHide(index)">

        <h3>2018年0{{index+6}}月</h3>

        <div class="number">800笔<i></i></div>

      </div>

      <div class="contant">

        <ul>

          <li v-for="i in item.allNumber">
            {{index+6}}
          </li>
        </ul>
      </div>
    </div>
  </div>
</template>
<script>
export default{
  data(){
    return{
      items:[
        {v:'qqq',allNumber:1},

        {v:'aaa',allNumber:2},

        {v:'qqq',allNumber:3},

      ],
    }
  },
  created(){
    document.body.style.backgroundColor = '#f6f6f6';
  },

  mounted(){

    for(var i=0;i<3;i++){  //这里取值自后台返回的长度,设置页面渲染完成后是否展开,此处不展开

      document.getElementsByClassName('contant')[i].style.height = '0px';

    }

  },

  components:{

  },

  methods:{

    showHide(index){  //点击展开收起

      let contant = document.getElementsByClassName('contant')[index];  //这里我们通过参数index来让浏览器判断你点击的是哪一个列表  

      let height = contant.getBoundingClientRect().height;  //获取页面元素的当前高度

      document.getElementsByTagName('i')[index].style.transform = !!height?'rotateX(0deg)':'rotateX(180deg)';

      if (!!height) {

      contant.style.height = height + 'px';

      let f = document.body.offsetHeight; //强制相应dom重绘,使最新的样式得到应用

      contant.style.height = '0px';

      } else {

      contant.style.height = 'auto';

      height = contant.getBoundingClientRect().height;

      contant.style.height = '0';

      let f = document.body.offsetHeight;

      contant.style.height = height + 'px';

      }
    }
  },

  beforeDestroy(){
    document.body.style.backgroundColor = '#fff';
  }
}
</script>
<style type="text/scss" lang="scss" scoped>
.dealRecord-wrap{margin-bottom: 100px;

  .title-contant{overflow: hidden;  /* 这个是重点 */

    .title{height: 84px;padding: 0 24px;border-bottom: 1px solid #eaeaea;/*px*/

      h3{height: 84px;font-size: 28px;color: #333;display: flex;align-items: center;float: left;;margin-left: 10px;}

      .number{height: 84px;font-size: 24px;color: #666;display: flex;align-items: center;float: right;}

      .number i{display: inline-block;width: 23px;height: 13px;background: url('../../assets/images/icon_dropup@2x.png');background-repeat: no-repeat;background-size: 23px 13px;background-position: right 6px center;padding-right: 35px;display: flex;align-items: center; float: right;transform:rotateX(0deg);}

    }

    .contant{background: #fff;transition: height 1s;  /* 这个也是重点 */

      ul li{padding: 0 24px;height: 142px;display: flex;align-items: center;}

      ul li:not(:last-child){border-bottom: 1px solid #f6f6f6;/*px*/}
    }
  }
}
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。 

Javascript 相关文章推荐
在textarea文本域中显示HTML代码的方法
Mar 06 Javascript
jquery text()要注意啦
Oct 30 Javascript
jquery中选择块并改变属性值的方法
Jul 31 Javascript
javaScript实现可缩放的显示区效果代码
Oct 26 Javascript
JS基于ocanvas插件实现的简单画板效果代码(附demo源码下载)
Apr 05 Javascript
JavaScript判断微信浏览器实例代码
Jun 13 Javascript
JavaScript操作文件_动力节点Java学院整理
Jun 30 Javascript
Webpack devServer中的 proxy 实现跨域的解决
Jun 15 Javascript
原生JS实现动态加载js文件并在加载成功后执行回调函数的方法
Dec 30 Javascript
JavaScript解析及序列化JSON的方法实例分析
Jan 04 Javascript
微信小程序如何播放腾讯视频的实现
Sep 20 Javascript
原生JS实现飞机大战小游戏
Jun 09 Javascript
微信小程序实现聊天对话(文本、图片)功能
Jul 06 #Javascript
微信小程序使用wxParse解析html的方法教程
Jul 06 #Javascript
小程序实现发表评论功能
Jul 06 #Javascript
vue中倒计时组件的实例代码
Jul 06 #Javascript
微信小程序websocket实现聊天功能
Mar 30 #Javascript
vue中锚点的三种方法
Jul 06 #Javascript
Angularjs中date过滤器失效的问题及解决方法
Jul 06 #Javascript
You might like
PHP中如何调用webservice的实例参考
2013/04/25 PHP
解析PHP正则提取或替换img标记属性
2013/06/26 PHP
php实现爬取和分析知乎用户数据
2016/01/26 PHP
php实现通过stomp协议连接ActiveMQ操作示例
2020/02/23 PHP
PHP正则之正向预查与反向预查讲解与实例
2020/04/06 PHP
国外Lightbox v2.03.3 最新版 下载
2007/10/17 Javascript
使用JavaScript检测Firefox浏览器是否启用了Firebug的代码
2010/12/28 Javascript
5秒后跳转效果(setInterval/SetTimeOut)
2013/05/03 Javascript
javascript中HTMLDOM操作详解
2014/12/11 Javascript
javascript制作的简单注册模块表单验证
2015/04/13 Javascript
JS 拼凑字符串的简单实例
2016/09/02 Javascript
利用ES6语法重构React组件详解
2017/03/02 Javascript
JS简单获取日期相差天数的方法
2017/04/24 Javascript
Javascript 严格模式use strict详解
2017/09/16 Javascript
简单实现jQuery弹窗效果
2017/10/30 jQuery
jquery+css3实现熊猫tv导航代码分享
2018/02/12 jQuery
JS实现全屏预览F11功能的示例代码
2018/07/23 Javascript
使用vuex较为优雅的实现一个购物车功能的示例代码
2019/12/09 Javascript
vue3.0+vue-router+element-plus初实践
2020/12/02 Vue.js
Python的Django框架中自定义模版标签的示例
2015/07/20 Python
Python列表(List)知识点总结
2019/02/18 Python
Python编写合并字典并实现敏感目录的小脚本
2019/02/26 Python
python动态视频下载器的实现方法
2019/09/16 Python
python之pymysql模块简单应用示例代码
2019/12/16 Python
Pytorch中膨胀卷积的用法详解
2020/01/07 Python
基于Python词云分析政府工作报告关键词
2020/06/02 Python
HTML 5 input placeholder 属性如何完美兼任ie
2014/05/12 HTML / CSS
毕业生自荐书
2014/02/02 职场文书
开朗女孩的自我评价
2014/02/10 职场文书
大学生简短的自我评价分享
2014/02/20 职场文书
安全生产管理责任书
2014/04/16 职场文书
说明书格式及范文
2014/05/07 职场文书
应届生求职信范文
2014/06/30 职场文书
小学生感恩父母演讲稿
2014/08/28 职场文书
办公室主任岗位职责
2015/01/31 职场文书
pyqt5打包成exe可执行文件的方法
2021/05/14 Python