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 相关文章推荐
jQuery实用基础超详细介绍
Apr 11 Javascript
使用Js让Html中特殊字符不被转义
Nov 05 Javascript
JavaScript数组深拷贝和浅拷贝的两种方法
Apr 16 Javascript
javascript同步服务器时间和同步倒计时小技巧
Sep 24 Javascript
Vue.js实现无限加载与分页功能开发
Nov 03 Javascript
原生js实现下拉框功能(支持键盘事件)
Jan 13 Javascript
vue-cli入门之项目结构分析
Apr 20 Javascript
详解用webpack2搭建angular2的项目
Jun 22 Javascript
Vue.js中的图片引用路径的方式
Jul 28 Javascript
vue利用better-scroll实现轮播图与页面滚动详解
Oct 20 Javascript
解决vue中修改了数据但视图无法更新的情况
Aug 27 Javascript
vue-cli整合vuex的时候,修改actions和mutations,实现热部署的方法
Sep 19 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 include的妙用,实现路径加密
2008/07/29 PHP
PHP中函数内引用全局变量的方法
2008/10/20 PHP
一个显示某段时间内每个月的方法 返回由这些月份组成的数组
2012/05/16 PHP
thinkphp中多表查询中防止数据重复的sql语句(必看)
2016/09/22 PHP
JS 控制CSS样式表
2009/08/20 Javascript
在模板页面的js使用办法
2010/04/01 Javascript
jQuery学习笔记之jQuery的动画
2010/12/22 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
JS数组去重与取重的示例代码
2014/01/24 Javascript
JavaScript中的Function函数
2015/08/27 Javascript
一道JS前端闭包面试题解析
2015/12/25 Javascript
浅析JavaScript中的变量复制、参数传递和作用域链
2016/01/13 Javascript
深入理解JQuery中的事件与动画
2016/05/18 Javascript
关于javascript中限定时间内防止按钮重复点击的思路详解
2016/08/16 Javascript
利用Angular.js编写公共提示模块的方法教程
2017/05/28 Javascript
vue.js vue-router如何实现无效路由(404)的友好提示
2017/12/20 Javascript
js中this对象用法分析
2018/01/05 Javascript
Vue父子组件之间的通信实例详解
2018/09/28 Javascript
微信小程序自定义带价格显示日历效果
2018/12/29 Javascript
详解Vue中的自定义指令
2020/12/07 Vue.js
JavaScript实现点击切换验证码及校验
2021/01/10 Javascript
python实现linux下使用xcopy的方法
2015/06/28 Python
解决pycharm remote deployment 配置的问题
2019/06/27 Python
tensorflow 保存模型和取出中间权重例子
2020/01/24 Python
Python批量将图片灰度化的实现代码
2020/04/11 Python
python 三种方法实现对Excel表格的读写
2020/11/19 Python
Python json解析库jsonpath原理及使用示例
2020/11/25 Python
HTML5事件方法全部汇总
2016/05/12 HTML / CSS
Nike英国官网:Nike.com (UK)
2017/02/13 全球购物
学校春季防火方案
2014/06/08 职场文书
党支部活动策划方案
2014/08/18 职场文书
村安全生产责任书
2014/08/25 职场文书
2015年建党94周年演讲稿
2015/03/19 职场文书
2015年电气技术员工作总结
2015/07/24 职场文书
小学生大队委竞选稿
2015/11/20 职场文书
php去除deprecated的实例方法
2021/11/17 PHP