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

前端之家收集整理的这篇文章主要介绍了Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_4030@

需求分析:


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

@H_403_0@点击红框前:

这里写图片描述

@H_403_0@点击后:

这里写图片描述

@H_403_0@

难点分析:

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

<Meta charset="UTF-8"> Title
Box"> Box">
Box" v-show="Boxshow">

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


@H_403_0@

解决方案:


@H_403_0@

1、实现一个函数式组件


<div class="jb51code">
<pre class="brush:js;">
本人命名为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)
}
}

@H_403_0@

2、引用此组件

这里写图片描述

@H_403_0@在components中注册了此组件:

这里写图片描述

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

这里写图片描述

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

@H_403_0@实现效果

这里写图片描述

@H_403_0@

总结

@H_403_0@以上所述是小编给大家介绍的Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

原文链接:https://www.f2er.com/vue/31860.html

猜你在找的Vue相关文章