最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法

来源:动视网 责编:小采 时间:2020-11-27 19:36:25
文档

关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法

关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法:这篇文章主要介绍了Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下需求分析:如图,有很多高度不固定的模块(图中只显示两个,本人项目有十三个),点击模块标题展开相应的模块
推荐度:
导读关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法:这篇文章主要介绍了Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下需求分析:如图,有很多高度不固定的模块(图中只显示两个,本人项目有十三个),点击模块标题展开相应的模块
这篇文章主要介绍了Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

需求分析:

如图,有很多高度不固定的模块(图中只显示两个,本人项目有十三个),点击模块标题展开相应的模块,再次点击此模块匿藏,如何实现此需求并实现复用?

点击红框前:

这里写图片描述

点击后:

这里写图片描述

难点分析:

模块高度不固定。比如,本人一开始想到的方法如下:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <style>
 .box{
 height:500px;
 background-color:black; 
 overflow: hidden; 
 }
 .mybox-leave-active,.mybox-enter-active{
 transition: all 1s ease; 
 }
 .mybox-leave-active,.mybox-enter{
 height:0px !important;
 }
 .mybox-leave,.mybox-enter-active{
 height: 500px;
 }
 </style>
</head>
<body>
<p id="box">
 <transition name="mybox">
 <p class="box" v-show="boxshow"></p>
 </transition>
 <button @click="togglebox">按钮</button>
</p>
</body>
<script src="../bower_components/vue/dist/vue.js"></script>
<script>
 new Vue({
 el:'#box',
 data:{
 boxshow:false
 },
 methods:{

 togglebox:function(){
 this.boxshow = !this.boxshow;
 }
 } 
 });
</script>
</html>

这种方法确实可以实现点击展开,再次点击收缩的需求,但是有一个明显的缺点:限定了容器的高度,也就是每个模块都需要固定高度,并不适用于需求场景。

解决方案:

1、实现一个函数式组件

本人命名为vertical-toggle.js
// Created by xiaoqiang on 17/04/2018.
const elTransition = '0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out'
const Transition = {
 'before-enter' (el) {
 el.style.transition = elTransition
 if (!el.dataset) el.dataset = {}
 el.dataset.oldPaddingTop = el.style.paddingTop
 el.dataset.oldPaddingBottom = el.style.paddingBottom
 el.style.height = 0
 el.style.paddingTop = 0
 el.style.paddingBottom = 0
 },
 'enter' (el) {
 el.dataset.oldOverflow = el.style.overflow
 if (el.scrollHeight !== 0) {
 el.style.height = el.scrollHeight + 'px'
 el.style.paddingTop = el.dataset.oldPaddingTop
 el.style.paddingBottom = el.dataset.oldPaddingBottom
 } else {
 el.style.height = ''
 el.style.paddingTop = el.dataset.oldPaddingTop
 el.style.paddingBottom = el.dataset.oldPaddingBottom
 }
 el.style.overflow = 'hidden'
 },
 'after-enter' (el) {
 el.style.transition = ''
 el.style.height = ''
 el.style.overflow = el.dataset.oldOverflow
 },
 'before-leave' (el) {
 if (!el.dataset) el.dataset = {}
 el.dataset.oldPaddingTop = el.style.paddingTop
 el.dataset.oldPaddingBottom = el.style.paddingBottom
 el.dataset.oldOverflow = el.style.overflow
 el.style.height = el.scrollHeight + 'px'
 el.style.overflow = 'hidden'
 },
 'leave' (el) {
 if (el.scrollHeight !== 0) {
 el.style.transition = elTransition
 el.style.height = 0
 el.style.paddingTop = 0
 el.style.paddingBottom = 0
 }
 },
 'after-leave' (el) {
 el.style.transition = ''
 el.style.height = ''
 el.style.overflow = el.dataset.oldOverflow
 el.style.paddingTop = el.dataset.oldPaddingTop
 el.style.paddingBottom = el.dataset.oldPaddingBottom
 }
}
export default {
 name: 'VerticalToggle',
 functional: true,
 render (h, { children }) {
 const data = {
 on: Transition
 }
 return h('transition', data, children)
 }
}

2、引用此组件

这里写图片描述

在components中注册了此组件:

这里写图片描述

即可在teamplate中引用,请留意红框文字说明部分。

这里写图片描述

至此,Vue.js实现垂直展开、收缩不定高度模块组件实现完成及应用均已完成。

实现效果:

这里写图片描述

文档

关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法

关于Vue.JS实现垂直方向展开和收缩不定高度模块的JS组件的方法:这篇文章主要介绍了Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下需求分析:如图,有很多高度不固定的模块(图中只显示两个,本人项目有十三个),点击模块标题展开相应的模块
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top