您好,登录后才能下订单哦!
密码登录
            
            
            
            
        登录注册
            
            
            
        点击 登录注册 即表示同意《亿速云用户服务条款》
        最近公司项目加了个页面,其中要求是这样的,点击对应列表,展开和收起,其实就是显示和隐藏内容部分;说来惭愧,我花了半天时间才搞出来(自黑一下~),接下来分享给大家,先上效果图:

vue页面:
<template>
  <div class="dealRecord-wrap">
    <div class="title-contant" v-for="(item,index) in items " >
      <div class="title" @click="showHide(index)">
        <h4>2018年0{{index+6}}月</h4>
        <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*/
      h4{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> 
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。 
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。