我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue+antd实现折叠与展开组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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,
    }"
    :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>

完成!!

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

展开效果:

折叠效果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue+antd实现折叠与展开组件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

详解GoJs节点的折叠展开实现

这篇文章主要为大家介绍了GoJs节点的折叠展开实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-18

Android TextView实现多文本折叠、展开效果

背景在开发过程中,当我们的需求中包含说说或者评论等内容的展示时,我们都会考虑当内容太多时该如何显示。当内容的字数太多,如果全部展示出来可能会影响体验效果,但是又不能只截取一部分内容进行展示,此时就需要考虑使用多行显示折叠的效果来实现。效果图
2023-05-31

Android UI实现多行文本折叠展开效果

上文介绍了单行文本水平触摸滑动效果,通过EditText实现TextView单行长文本水平滑动效果。 本文继续介绍了多行文本折叠展开,自定义布局View实现多行文本折叠和展开 1.概述 经常在APP中能看到有引用文章或大段博文的内容,他们的
2022-06-06

小程序如何实现多折叠展开菜单

这篇文章主要讲解了“小程序如何实现多折叠展开菜单”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“小程序如何实现多折叠展开菜单”吧!小程序实现多折叠展开菜单效果展示:  开始正题  上方Nav 
2023-06-26

微信小程序实现页面折叠展开效果

微信小程序实现页面折叠展开效果微信小程序作为一款轻量级的移动应用开发工具,提供了丰富的界面组件和简单的开发语法,方便开发者开发小程序应用。本文将介绍如何利用微信小程序实现页面的折叠展开效果,并提供具体的代码示例供参考。一、实现思路要实现页面
微信小程序实现页面折叠展开效果
2023-11-21

微信小程序实现列表项展开折叠功能

微信小程序实现列表项展开折叠功能,需要具体代码示例导言:微信小程序是一种快速开发、跨平台的应用程序,它提供了丰富的 API 和组件,可以轻松地开发和发布小程序,满足用户的不同需求。在开发小程序时,常常遇到需要展示列表的场景,而有时候列表过长
微信小程序实现列表项展开折叠功能
2023-11-21

Visual Studio 2010扩展让JS与CSS实现折叠的示例分析

今天就跟大家聊聊有关Visual Studio 2010扩展让JS与CSS实现折叠的示例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在Visaul Studio 2010中写j
2023-06-17

Vue下如何用递归组件实现一个可折叠的树形菜单

这篇文章主要介绍“Vue下如何用递归组件实现一个可折叠的树形菜单”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue下如何用递归组件实现一个可折叠的树形菜单”文章能帮助大家解决问题。在Vue.js中
2023-07-04

vue怎么实现探探滑动堆叠组件

这篇文章主要讲解了“vue怎么实现探探滑动堆叠组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue怎么实现探探滑动堆叠组件”吧!一. 功能分析简单使用下探探会发现,堆叠滑动的功能很简单,
2023-07-04

Android Studio使用recyclerview实现展开和折叠(在之前的微信页面基础之上)

Android Studio使用recyclerview实现展开和缩回(在之前的微信页面基础之上)Android中RecyclerView点击item展开列表详细内容github源码地址: Android中RecyclerView点击ite
2022-06-06

Vue使用antd组件a-form-model实现数据连续添加功能

这篇文章主要介绍了Vue使用antd组件a-form-model实现数据连续添加功能,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-24

amazeui树节点自动展开折叠面板并选中第一个树节点的实现方法

这篇文章主要介绍amazeui树节点自动展开折叠面板并选中第一个树节点的实现方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Amaze UI Tree是Amaze框架的扩展,优点是风格与Amaze框架一致,缺点是很
2023-06-09

编程热搜

目录