中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用vue+antd實現折疊與展開組件

發布時間:2022-09-22 09:45:26 來源:億速云 閱讀:479 作者:iii 欄目:開發技術

今天小編給大家分享一下怎么用vue+antd實現折疊與展開組件的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

效果圖如下:

怎么用vue+antd實現折疊與展開組件

由于其它地方也需要實現這種功能,所以,需要封裝成一個組件。

代碼如下:

1. 父頁面代碼

1.1 變量:open:表示現在的狀態,true是展開,false為折疊

1.2 變量:height:表示折疊時的高度,也就是根據標題的高度來的。

1.3 插槽:在組件中寫的內容是一個插槽,可以預知組件內有個<slot></slot>來接收外部的內容

<openCloseBox :open="true" :height="40">
  <div class="card_tit">
    <a-icon type="minus" /><span class="tab_tit">常規工藝</span>
  </div>
  <div class="card_con">
    <a-row>
      <a-col :span="12">產品類型:常規</a-col>
      <a-col :span="12">板子大小:常規</a-col>
      <a-col :span="12">出貨方式:常規</a-col>
      <a-col :span="12">交貨數量: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,
    }"
    :
  >
    <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>

完成!!

其它地方引用的效果如下:

展開效果:

怎么用vue+antd實現折疊與展開組件

折疊效果:

怎么用vue+antd實現折疊與展開組件

以上就是“怎么用vue+antd實現折疊與展開組件”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

嘉黎县| SHOW| 咸丰县| 班戈县| 洪江市| 公主岭市| 杭州市| 同仁县| 海南省| 苏尼特左旗| 宁明县| 阿城市| 邹城市| 怀柔区| 东辽县| 衡阳市| 岳阳市| 金堂县| 三亚市| 平谷区| 如皋市| 洞头县| 巴彦县| 五常市| 乳源| 阳西县| 资中县| 永顺县| 淄博市| 祁门县| 台南市| 蒙山县| 偏关县| 丰都县| 肃宁县| 临桂县| 勃利县| 浦县| 乳源| 安陆市| 东乡|