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>

完成!!

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

展开效果:

折叠效果:

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

(0)

相关推荐

  • vue同个按钮控制展开和折叠同个事件操作

    我就废话不多说了,大家还是直接看代码吧~ <el-button :icon="!moreshow?'el-icon-arrow-down':'el-icon-arrow-up'" @click="getmoreshow">{{!moreshow?更多:隐藏}}</el-button> data() { return { moreshow:false, count:1, } } mounted() { this.getmoreshow()//避

  • vue多级复杂列表展开/折叠及全选/分组全选实现

    首先,来看下效果图 在线体验地址:https://hxkj.vip/demo/multipleList/.温馨提示,打开之后按F12,使用手机模式食用,口味更佳! 可以看出,这个列表有三种展现形式: 1.第一层级中包含直属子项和第二层级,其中第二层级里包含子项 2.第一层级中只包含第二层级,第二层级里包含子项 3.第一层级中只包含直属子项 接下来,再分析列表所实现的功能: 1.点击父级可以展开与折叠该直属子级: 2.点击父级级的勾选图标可以全选或取消该层级下列的所有子项: 3.点击子项达到该父级

  • Vue 实现展开折叠效果的示例代码

    本文介绍了Vue 实现展开折叠效果的示例代码,分享给大家,具体如下: 效果如见: 1.html代码 <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>js文本段落展开和收拢效果</title> <script type="text/javasc

  • Vue3+Element-Plus实现左侧菜单折叠与展开功能示例

    目录 1.最终实现的效果图 2.  实现左侧菜单折叠与展开功能步骤 2.1 首先应该在菜单顶部放一个折叠展开的按钮条 2.2 接下来,画按钮条UI结构,实现折叠与展开功能 2.3  实现点击该DIV时,触发菜单折叠与展开 2.4  折叠与展开功能是实现了,但是背景颜色并没有随着菜单折叠时跟着变小或展开时跟着变大 2.5. 最终效果 3. Home.vue 代码 1.最终实现的效果图 2.  实现左侧菜单折叠与展开功能步骤 2.1 首先应该在菜单顶部放一个折叠展开的按钮条 2.2 接下来,画按钮条

  • vue-列表下详情的展开与折叠案例

    如下所示: 功能描述 1.默认折叠,点击时展示全部数据 2.点击A项,A展开,之后有两种情况:①再次点击A,A折叠:②点击其他项,如B,这时B展开,A折叠 解决方式 1.给展开折叠图标添加一个样式,显示成动画效果 <div class="arrow" :class="{'open':showDetail === index}"></div> .arrow{ position absolute width: 0.6rem; height: 0.

  • vuejs实现折叠面板展开收缩动画效果

    vuejs通过css3实现元素固定高度到auto高度的动画和auto高度到固定高度的动画. 循环列表,html: <template> <div class="newslist"> <ul> <li v-for="(item,index) in newslist" :key="index"> <p class="p" ref="liCon">{{i

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

    最近在写前台页面,遇到一个需求,如下:点击头部标题,如果有内容,则展开,否则不展开,其实就是展开与折叠的组件.效果图如下: 由于其它地方也需要实现这种功能,所以,需要封装成一个组件. 代码如下: 1. 父页面代码 1.1 变量:open:表示现在的状态,true是展开,false为折叠 1.2 变量:height:表示折叠时的高度,也就是根据标题的高度来的. 1.3 插槽:在组件中写的内容是一个插槽,可以预知组件内有个<slot></slot>来接收外部的内容 <openCl

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

    需求分析: 如图,有很多高度不固定的模块(图中只显示两个,本人项目有十三个),点击模块标题展开相应的模块,再次点击此模块匿藏,如何实现此需求并实现复用? 点击红框前: 点击后: 难点分析: 模块高度不固定.比如,本人一开始想到的方法如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title

  • vue控制多行文字展开收起的实现示例

    这里讲一下,如何使用vue控制多行文字展开收起(也叫控制文字展开隐藏). 效果: 这里设置了控制三行,如果超过三行会展示,"显示更多" 超出文字显示省略号.点击"显示更多"会展开所有文案,按钮变成"收起" (未超出三行的时候) (展开) (收起) 代码实现: <template> <div> <p class="m-content overflow-line" id="J_descrip

  • vue基于el-table拓展之table-plus组件

    目录 目的 源码 文档 TablePlus Attributes TablePlus Events TablePlus Methods TablePlus column TablePlus spanConfig 基本用法 目的 配置型表格多级表头/自定义表头.形数据与懒加载用法等支持el-table大部分属性和用法 内置loading加载 内置合并单元格 默认跨页选择 自定义列模板 划重点:后面tableSmart的基础组件 源码 包裹层TableWrap.vue <template> <

  • vue封装一个图案手势锁组件

    目录 说在前面 效果展示 预览地址 实现步骤 1.组件设计 2.组件分析 3.组件实现 4.组件使用 组件库引用 源码地址 组件文档 说在前面 现在很多人都喜欢使用图案手势锁,这里我使用vue来封装了一个可以直接使用的组件,在这里记录一下这个组件的开发步骤. 效果展示 组件实现效果如下图: 预览地址 http://jyeontu.xyz/jvuewheel/#/JAppsLock 实现步骤 完成一个组件需要几步? 1.组件设计 首先我们应该要知道我们要做怎样的组件,具备怎样的功能,这样才可以开始

  • Vue 过渡(动画)transition组件案例详解

    Vue过度(动画),本质走的是CSS3:transtion,animation. 控制器div显示/隐藏,代码如下: <div id="box"> <input type="button" value="按钮" @click="toggle"> <div id="div1" v-show="isShow"></div> </div&g

  • 详解Vue.use自定义自己的全局组件

    通常我们在vue里面使用别人开发的组件,第一步就是install,第二步在main.js里面引入,第三步Vue.use这个组件.今天我简单的也来use一个自己的组件. 这里我用的webpack-simple这个简单版本的脚手架为例,安装就不啰嗦了,直接进入正题 首先看下目前的项目结构: webpack首先会加载main.js,所以我们在main的js里面引入.我以element ui来做对比说明 import Vue from 'vue' import App from './App.vue'

随机推荐