程序员scholar 程序员scholar
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
npm

(进入注册为作者充电)

  • 原生微信小程序

  • uniapp多端开发

    • 快速入门

    • 内置组件

    • 扩展组件

      • uni-ui 介绍
      • Uni-UI 的安装和使用
      • uni-sass 辅助样式
      • uni-badge 数字角标
      • uni-breadcrumb 面包屑
      • uni-calendar 日历
      • uni-card 卡片
      • uni-collapse 折叠面板
        • 介绍
          • 基本用法
          • 手风琴效果
          • 动态设置折叠面板打开状态
          • 使用动画
          • 配置图片
          • 自定义插槽
        • API
          • Collapse Props
          • Collapse Event
          • Collapse Methods
          • CollapseItem Props
          • TitleBorder Params
          • Collapse Slots
        • 示例
      • uni-combox 组合框
      • uni-countdown 倒计时
      • uni-data-checkbox 数据选择器
      • uni-data-picker 级联选择器
      • uni-data-select 下拉框
      • uni-dateformat 日期格式化
      • uni-datetime-picker 日期选择器
      • uni-drawer 抽屉
      • uni-easyinput 增强输入框
      • uni-fab 悬浮按钮
      • uni-fav 收藏按钮
      • uni-file-picker 文件选择上传
      • uni-forms 表单
      • uni-goods-nav 商品导航
      • uni-grid 宫格
      • uni-group 分组
      • uni-icons 图标
      • uni-indexed-list 索引列表
      • uni-link 超链接
      • uni-list 列表
      • uni-load-more 加载更多
      • uni-nav-bar 自定义导航栏
      • uni-notice-bar 通告栏
      • uni-number-box 数字输入框
      • uni-pagination 分页器
      • uni-popup 弹出层
      • uni-rate 评分
      • uni-row 布局-行
      • uni-search-bar 搜索栏
      • uni-section 标题栏
      • uni-segmented-control 分段器
      • uni-steps 步骤条
      • uni-swipe-action 滑动操作
      • uni-swiper-dot 轮播图指示点
      • uni-table 表格
      • uni-tag 标签
      • uni-title 章节标题
      • uni-tooltip 文字提示
      • uni-transition 过渡动画
  • 小程序开发
  • uniapp多端开发
  • 扩展组件
scholar
2024-10-21
目录

uni-collapse 折叠面板

组件名:uni-collapse

代码块: uCollapse

关联组件:uni-collapse-item、uni-icons。

点击下载&安装 (opens new window)

折叠面板用来折叠/显示过长的内容或者是列表。通常是在多内容分类项使用,折叠不重要的内容,显示重要内容。点击可以展开折叠部分。

# 介绍

注意事项

为了避免错误使用,给大家带来不好的开发体验,请在使用组件前仔细阅读下面的注意事项,可以帮你避免一些错误。

  • 组件需要依赖 sass 插件 ,请自行手动安装
  • App 端默认关闭组件动画 ,因为 height 动画开销比较大,会导致页面卡顿,请酌情使用动画
  • 如在使用组件过程从发现卡顿严重,请尝试停用组件动画,问题原因如上
  • 在小程序端组件内容发生变化,需要手动调用 resize() 方法,手动更新几点信息,避免出现内容错位
  • 如需自定义组件默认边框颜色等,请使用插槽自定义内容并合理使用 border 和 title-border 属性
  • uni-collapse-item 仅支持嵌套使用,请勿单独使用
  • 组件支持 nvue ,需要在 manifest.json > app-plus 节点下配置 "nvueStyleCompiler" : "uni-app"

# 基本用法

使用 title 属性指定面板显示内容

使用 open 属性默认打开当前面板

使用 disabled 属性禁用面板

<uni-collapse>
	<uni-collapse-item title="默认开启" :open="true">
		<text>折叠内容</text>
	</uni-collapse-item>
	<uni-collapse-item title="折叠内容">
			<text>折叠内容</text>
	</uni-collapse-item>
	<uni-collapse-item title="禁用状态" disabled>
		<text>折叠内容</text>
	</uni-collapse-item>
</uni-collapse>
1
2
3
4
5
6
7
8
9
10
11

# 手风琴效果

使用 accordion 属性,可以仅打开一个面板并关闭其他已经打开的面板,效果类似手风琴

设置 accordion 属性时,open 属性则生效在最后一个组件

<uni-collapse accordion>
	<uni-collapse-item title="手风琴效果">
		<text>折叠内容</text>
	</uni-collapse-item>
	<uni-collapse-item title="手风琴效果">
			<text>折叠内容</text>
	</uni-collapse-item>
	<uni-collapse-item title="禁用状态" disabled>
		<text>折叠内容</text>
	</uni-collapse-item>
</uni-collapse>
1
2
3
4
5
6
7
8
9
10
11

# 动态设置折叠面板打开状态

使用 v-model 属性,动态设置面板的显示状态

使用 name 属性设置每个面板的唯一标识,如不设置使用默认索引,从字符串 "0" 开始记数

注意

  • 如果 accordion 属性为 true 则 v-model 类型为 String
  • 如果 accordion 属性为 false 则 v-model 类型为 Array
  • 请注意 v-model 属性与 open 属性请勿一起使用 ,建议只使用 v-model
    <uni-collapse v-model="value">
    	<uni-collapse-item name="key1" title="默认开启">
    		<text>折叠内容</text>
    	</uni-collapse-item>
    	<uni-collapse-item name="key2" title="默认开启">
    			<text>折叠内容</text>
    	</uni-collapse-item>
    	<uni-collapse-item name="key3" title="默认不开启">
    			<text>折叠内容</text>
    	</uni-collapse-item>
    </uni-collapse>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    export default {
    	data(){
    		return {
    			value:['key1','key2'],
    			// 如果设置了 accordion 属性,则使用 string 类型
    			// value:'key1'
    		}
    	}
    }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    // Make sure to add code blocks to your code group

    # 使用动画

    使用 show-animation 属性开启或关闭面板折叠动画,默认动画开启

    注意

    • App 端默认关闭组件动画 ,因为 height 动画开销比较大,会导致页面卡顿,请酌情使用动画,如出现明显卡顿,尝试关闭动画
    <uni-collapse>
    	<uni-collapse-item :show-animation="true" title="开启动画">
    		<text>折叠内容</text>
    	</uni-collapse-item>
    	<uni-collapse-item :show-animation="true"  title="开启动画">
    			<text>折叠内容</text>
    	</uni-collapse-item>
    	<uni-collapse-item :show-animation="false"  title="不开启动画">
    			<text>折叠内容</text>
    	</uni-collapse-item>
    </uni-collapse>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11

    # 配置图片

    使用 thumb 配置图片地址, 可在面板左侧显示一个图片

    如需显示更多内容,如图标等,请见下方自定义插槽的说明

    <uni-collapse>
    	<uni-collapse-item title="标题文字"
    		thumb="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png">
    		<view class="content">
    			<text class="text">折叠内容主体,可自定义内容及样式</text>
    		</view>
    	</uni-collapse-item>
    </uni-collapse>
    
    1
    2
    3
    4
    5
    6
    7
    8

    # 自定义插槽

    如果需要自定义面板显示,可以使用 title 插槽达成完全自定义。下面是一个使用 uni-list 的列表示例,需要引入 uni-list 组件

    <uni-collapse>
    	<!-- 因为list默认带一条分隔线,所以使用 titleBorder="none" 取消面板的分隔线 -->
    	<uni-collapse-item title-border="none" :border="false">
    		<template v-slot:title>
    			<uni-list>
    				<uni-list-item title="标题使用自定义标题插槽" :show-extra-icon="true" :extra-icon="extraIcon">
    				</uni-list-item>
    			</uni-list>
    		</template>
    		<view class="content">
    			<text class="text">折叠内容主体,可自定义内容及样式</text>
    		</view>
    	</uni-collapse-item>
    </uni-collapse>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14

    注意

    • 在折叠面板组件中使用list时,在 App-Nvue 下请勿单独使用 uni-list-item,会导致组件无法正常显示,其他平台不做限制
    • 在默认插槽里使用 uni-list 组件与上方示例一样,直接写在默认插槽里即可

    # API

    # Collapse Props

    属性名 类型 默认值 说明
    value/v-model String/Array - 当前激活面板改变时触发(如果是手风琴模式,参数类型为string,否则为array)
    accordion Boolean false 是否开启手风琴效果

    # Collapse Event

    事件称名 说明 返回值
    @change 切换面板时触发 切换面板时触发,如果是手风琴模式,返回类型为string,否则为array

    # Collapse Methods

    方法名称 说明
    resize 更新当前列表高度

    提示

    • resize 方法解决动态添加数据,带动画的折叠面板高度不更新的问题
    • 需要在数据渲染完毕之后使用 resize 方法。推荐在 this.$nextTick() 中使用
    • 当前只有小程序端需要调用此方法,H5\App 端已经做了处理,不需要手动更新高度

    示例:

      <template>
      	<view>
      		<uni-collapse ref="collapse" v-model="value">
      			<uni-collapse-item title="默认开启" >
      				<view class="content">
      					<text class="text">{{content}}</text>
      				</view>
      			</uni-collapse-item>
      			<uni-collapse-item title="折叠内容">
      				<view class="content">
      					<text class="text">折叠内容主体,这是一段比较长内容。默认折叠主要内容,只显示当前项标题。点击标题展开,才能看到这段文字。再次点击标题,折叠内容。</text>
      				</view>
      			</uni-collapse-item>
      		</uni-collapse>
      		<button class="button" type="primary" @click="add">动态修改内容</button>
      	</view>
      </template>
      
      
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      <script>
      	export default {
      		data() {
      			return {
      				value:['0'],
      				content: '折叠内容主体,可自定义内容及样式,点击按钮修改内容使高度发生变化。',
      			}
      		},
      		methods: {
      			add() {
      				if (this.content.length > 35) {
      					this.content = '折叠内容主体,可自定义内容及样式,点击按钮修改内容使高度发生变化。'
      				} else {
      					this.content = '折叠内容主体,这是一段比较长内容。通过点击按钮修改后内容后,使组件高度发生变化,在次点击按钮恢复之前的内容和高度。'
      				}
      				// TODO 小程序中不支持自动更新 ,需要手动resize 更新组件高度
      				// #ifdef MP
      				this.$nextTick(() => {
      					this.$refs.collapse.resize()
      				})
      				// #endif
      			}
      		}
      	}
      </script>
      
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      24
      25
      // Make sure to add code blocks to your code group

      # CollapseItem Props

      属性名 类型 默认值 说明
      title String - 标题文字
      thumb String - 标题左侧缩略图
      disabled Boolean false 是否禁用
      open Boolean false 是否展开面板
      show-animation Boolean false 开启动画
      border Boolean true 折叠面板内容分隔线
      title-border String auto 折叠面板标题分隔线可选值见下方 TitleBorder Params
      show-arrow Boolean true 是否显示右侧箭头

      # TitleBorder Params

      参数名 说明
      auto 分隔线自动显示
      none 不显示分隔线
      show 一直显示分隔线

      # Collapse Slots

      插槽名 说明
      default 默认插槽
      title 面板标题插槽,如使用此插槽禁用样式效果将失效

      # 示例

      注意

      示例依赖了 uni-card uni-section uni-scss 等多个组件,直接拷贝示例代码将无法正常运行 。

      请到 组件下载页面 (opens new window) ,在页面右侧选择 使用 HBuilderX导入示例项目 ,体验完整示例演示 (opens new window)。

        <template>
        	<view>
        		<uni-card :is-shadow="false" is-full>
        			<text class="uni-h6">折叠面板用来折叠/显示过长的内容或者是列表。通常是在多内容分类项使用,折叠不重要的内容,显示重要内容。点击可以展开折叠部分。</text>
        		</uni-card>
        		<uni-section title="基础用法" type="line">
        			<uni-collapse ref="collapse" v-model="value" @change="change">
        				<uni-collapse-item title="默认开启" >
        					<view class="content">
        						<text class="text">{{content}}</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="折叠内容">
        					<view class="content">
        						<text class="text">折叠内容主体,这是一段比较长内容。默认折叠主要内容,只显示当前项标题。点击标题展开,才能看到这段文字。再次点击标题,折叠内容。</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="禁用状态" disabled>
        					<view class="content">
        						<text class="text">禁用状态内容主体,页面上是看不到这段话的。</text>
        					</view>
        				</uni-collapse-item>
        			</uni-collapse>
        		</uni-section>
        
        		<button class="button" type="primary" @click="add">动态修改内容</button>
        		<!-- TODO app 端默认不使用动画,app在使用高度动画的时候会有性能开销问题,所以应该要酌情使用 -->
        		<uni-section title="使用动画效果" type="line">
        			<uni-collapse >
        				<uni-collapse-item title="使用动画" :show-animation="true">
        					<view class="content">
        						<text class="text">默认开启组件动画,使用动画效果折叠内容会有一个从上到下的动画。</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="不使用动画" :show-animation="false">
        					<view class="content">
        						<text class="text">设置 show-animation="false",关闭当前组件动画效果。</text>
        					</view>
        				</uni-collapse-item>
        			</uni-collapse>
        		</uni-section>
        		<uni-section title="手风琴效果(只会保留一个的打开状态)" type="line">
        			<uni-collapse  accordion v-model="accordionVal" @change="change">
        				<uni-collapse-item title="手风琴效果">
        					<view class="content">
        						<text class="text">手风琴效果同时只会保留一个组件的打开状态,其余组件会自动关闭。</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="手风琴效果">
        					<view class="content">
        						<text class="text">手风琴效果同时只会保留一个组件的打开状态,其余组件会自动关闭。</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="手风琴效果">
        					<view class="content">
        						<text class="text">手风琴效果同时只会保留一个组件的打开状态,其余组件会自动关闭。</text>
        					</view>
        				</uni-collapse-item>
        			</uni-collapse>
        		</uni-section>
        
        		<uni-section title="配置图片" type="line">
        			<uni-collapse>
        				<uni-collapse-item title="标题文字"
        					thumb="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png">
        					<view class="content">
        						<text class="text">折叠内容主体,可自定义内容及样式</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="标题文字"
        					thumb="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png">
        					<view class="content">
        						<text class="text">折叠内容主体,可自定义内容及样式</text>
        					</view>
        				</uni-collapse-item>
        			</uni-collapse>
        		</uni-section>
        
        		<uni-section title="使用插槽" type="line">
        			<uni-collapse>
        				<uni-collapse-item titleBorder="none">
        					<template v-slot:title>
        						<uni-list>
        							<uni-list-item title="标题使用自定义标题插槽" :show-extra-icon="true" :extra-icon="extraIcon">
        							</uni-list-item>
        						</uni-list>
        					</template>
        					<view class="content">
        						<text class="text">折叠内容主体,可自定义内容及样式</text>
        					</view>
        				</uni-collapse-item>
        				<uni-collapse-item title="折叠内容使用 uni-list 组件">
        					<uni-list>
        						<uni-list-item title="列表文字"></uni-list-item>
        						<uni-list-item :disabled="true" title="列表文字" note="列表禁用状态"></uni-list-item>
        						<uni-list-item title="列表右侧显示 switch" :show-switch="true"></uni-list-item>
        						<uni-list-item :show-extra-icon="true" :extra-icon="extraIcon" title="列表左侧带扩展图标"></uni-list-item>
        						<uni-list-item title="列表左侧带略缩图" note="列表描述信息"
        							thumb="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png"
        							thumb-size="lg" rightText="右侧文字" showArrow></uni-list-item>
        						<uni-list-item title="开启点击反馈" clickable showArrow @click="onClick"></uni-list-item>
        					</uni-list>
        				</uni-collapse-item>
        			</uni-collapse>
        		</uni-section>
        	</view>
        </template>
        
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12
        13
        14
        15
        16
        17
        18
        19
        20
        21
        22
        23
        24
        25
        26
        27
        28
        29
        30
        31
        32
        33
        34
        35
        36
        37
        38
        39
        40
        41
        42
        43
        44
        45
        46
        47
        48
        49
        50
        51
        52
        53
        54
        55
        56
        57
        58
        59
        60
        61
        62
        63
        64
        65
        66
        67
        68
        69
        70
        71
        72
        73
        74
        75
        76
        77
        78
        79
        80
        81
        82
        83
        84
        85
        86
        87
        88
        89
        90
        91
        92
        93
        94
        95
        96
        97
        98
        99
        100
        101
        102
        103
        104
        105
        106
        107
        <script>
        	export default {
        		components: {},
        		data() {
        			return {
        				value:['0'],
        				accordionVal:'1',
        				content: '折叠内容主体,可自定义内容及样式,点击按钮修改内容使高度发生变化。',
        				extraIcon: {
        					color: '#4cd964',
        					size: '26',
        					type: 'image'
        				},
        			}
        		},
        		methods: {
        			add() {
        				if (this.content.length > 35) {
        					this.content = '折叠内容主体,可自定义内容及样式,点击按钮修改内容使高度发生变化。'
        				} else {
        					this.content = '折叠内容主体,这是一段比较长内容。通过点击按钮修改后内容后,使组件高度发生变化,在次点击按钮恢复之前的内容和高度。'
        				}
        				// TODO 小程序中不支持自动更新 ,需要手动resize 更新组件高度
        				// #ifdef MP
        				this.$nextTick(() => {
        					this.$refs.collapse.resize()
        				})
        				// #endif
        			},
        			onClick(e) {
        				uni.showToast({
        					title: '列表被点击'
        				})
        			},
        			change(e) {
        				console.log(e);
        			}
        		}
        	}
        </script>
        
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12
        13
        14
        15
        16
        17
        18
        19
        20
        21
        22
        23
        24
        25
        26
        27
        28
        29
        30
        31
        32
        33
        34
        35
        36
        37
        38
        39
        40
        <style lang="scss">
        	.example-body {
        		flex-direction: column;
        		flex: 1;
        	}
        
        	.content {
        		padding: 15px;
        	}
        
        	.text {
        		font-size: 14px;
        		color: #666;
        		line-height: 20px;
        	}
        
        	.button {
        		// margin-top: 10px;
        		margin: 10px;
        		margin-bottom: 0;
        	}
        </style>
        
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12
        13
        14
        15
        16
        17
        18
        19
        20
        21
        22
        // Make sure to add code blocks to your code group
        编辑此页 (opens new window)
        上次更新: 2025/02/03, 00:09:13
        uni-card 卡片
        uni-combox 组合框

        ← uni-card 卡片 uni-combox 组合框→

        Theme by Vdoing | Copyright © 2019-2025 程序员scholar
        • 跟随系统
        • 浅色模式
        • 深色模式
        • 阅读模式