vue+antd實(shí)現(xiàn)折疊與展開組件
最近在寫前臺頁面,遇到一個需求,如下:點(diǎn)擊頭部標(biāo)題,如果有內(nèi)容,則展開,否則不展開,其實(shí)就是展開與折疊的組件。效果圖如下:

由于其它地方也需要實(shí)現(xiàn)這種功能,所以,需要封裝成一個組件。
代碼如下:
1. 父頁面代碼
1.1 變量:open:表示現(xiàn)在的狀態(tài),true是展開,false為折疊
1.2 變量:height:表示折疊時的高度,也就是根據(jù)標(biāo)題的高度來的。
1.3 插槽:在組件中寫的內(nèi)容是一個插槽,可以預(yù)知組件內(nèi)有個<slot></slot>來接收外部的內(nèi)容
<openCloseBox :open="true" :height="40"> ? <div class="card_tit"> ? ? <a-icon type="minus" /><span class="tab_tit">常規(guī)工藝</span> ? </div> ? <div class="card_con"> ? ? <a-row> ? ? ? <a-col :span="12">產(chǎn)品類型:常規(guī)</a-col> ? ? ? <a-col :span="12">板子大?。撼R?guī)</a-col> ? ? ? <a-col :span="12">出貨方式:常規(guī)</a-col> ? ? ? <a-col :span="12">交貨數(shù)量:11</a-col> ? ? </a-row> ? </div> </openCloseBox>
1.4 組件引入
import openCloseBox from './modules/openCloseBox.vue';
export default {
? name: 'index',
? components: {
? ? openCloseBox,
? ?},
}2. 組件代碼
<template>
? <div
? ? class="openclose-box"
? ? :class="{
? ? ? 'openclose-card-open': isOpen && card,
? ? ? 'openclose-card-close': !isOpen && card,
? ? ? 'openclose-box-open': isOpen && !card,
? ? ? 'openclose-box-close': !isOpen && !card,
? ? }"
? ? :style="{ height: !isOpen && !card ? height + 'px' : 'auto' }"
? >
? ? <div
? ? ? class="openclose-btn"
? ? ? :class="{ 'openclose-btn-box': !card }"
? ? ? @click="isOpen = !isOpen"
? ? ></div>
? ? <a-card v-if="card">
? ? ? <slot></slot>
? ? </a-card>
? ? <slot v-else></slot>
? </div>
</template>
<script>
export default {
? name: 'OpenCloseBox',
? props: {
? ? open: {
? ? ? type: Boolean,
? ? ? default: false,
? ? },
? ? card: {
? ? ? type: Boolean,
? ? ? default: false,
? ? },
? ? height: {
? ? ? type: Number,
? ? ? default: 60,
? ? },
? },
? data() {
? ? return {
? ? ? isOpen: this.open,
? ? };
? },
};
</script>
<style lang="less" scoped>
.openclose-box {
? position: relative;
? /deep/ .ant-card-body {
? ? padding: 20px 18px;
? }
? .openclose-btn {
? ? font-size: 14px;
? ? line-height: 16px;
? ? color: #333;
? ? width: 100%;
? ? height: 56px;
? ? position: absolute;
? ? top: 0;
? ? right: 0;
? ? padding-right: 18px;
? ? display: flex;
? ? justify-content: flex-end;
? ? align-items: center;
? ? z-index: 1;
? ? user-select: none;
? ? cursor: pointer;
? ? .openclose-icon {
? ? ? color: #999;
? ? }
? ? &:hover {
? ? ? color: #f90;
? ? ? .openclose-icon {
? ? ? ? color: #f90;
? ? ? }
? ? }
? }
? .openclose-btn-box {
? ? height: 48px;
? }
}
.openclose-card-open {
? /deep/ .ant-card-body {
? ? height: auto;
? }
}
.openclose-card-close {
? /deep/ .ant-card-body {
? ? height: 56px;
? ? overflow: hidden;
? }
}
.openclose-box-open {
? height: auto;
}
.openclose-box-close {
? height: 60px;
? overflow: hidden;
}
</style>完成?。?/p>
其它地方引用的效果如下:
展開效果:

折疊效果:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue?調(diào)用瀏覽器攝像頭實(shí)現(xiàn)及原理解析
這篇文章主要為大家介紹了vue調(diào)用瀏覽器攝像頭實(shí)現(xiàn)及原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
ES6 Proxy實(shí)現(xiàn)Vue的變化檢測問題
Vue3.0將采用ES6 Proxy的形式重新實(shí)現(xiàn)Vue的變化檢測,在官方還沒給出新方法之前,我們先實(shí)現(xiàn)一個基于Proxy的變化檢測。感興趣的朋友跟隨小編一起看看吧2019-06-06
詳解vue之自行實(shí)現(xiàn)派發(fā)與廣播(dispatch與broadcast)
這篇文章主要介紹了詳解vue之自行實(shí)現(xiàn)派發(fā)與廣播(dispatch與broadcast),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
vue如何隨心所欲調(diào)整el-dialog中body的樣式
這篇文章主要介紹了vue如何隨心所欲調(diào)整el-dialog中body的樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
想到頭禿也想不到的Vue3復(fù)用組件還可以這么hack的用法
這篇文章主要為大家介紹了想到頭禿也想不到的Vue3復(fù)用組件還可以這么hack的用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04

