uni-collapse.vue 1.0 KB
Newer Older
M
mehaotian 已提交
1 2 3 4 5 6 7 8
<template>
	<!-- 父组件暂时无用,后续子组件联动需要使用到父组件 -->
	<view>
		<slot></slot>
	</view>
</template>

<script>
9
	import { ComponentPublicInstance } from 'vue'
M
mehaotian 已提交
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
	export default {
		name: "UniCollapse",
		props: {
			// 是否开启手风琴效果
			accordion: {
				type: Boolean,
				default: true
			}
		},
		data() {
			return {
				child_nodes: [] as Array < ComponentPublicInstance >
			};
		},

		methods: {
			init(child: ComponentPublicInstance) {
				this.child_nodes.push(child)
			},
			// 关闭所有
			cloceAll() {
				// 开启手风琴效果才回关闭其他
				if (this.accordion && this.child_nodes.length > 0) {
					this.child_nodes.forEach((item) => {
						const is_open = item.$data.get('is_open') as boolean
						// TODO 暂时无法获取子组件上的属性和方法,暂时使用绕过方案
						if (is_open) {
							item.$data.set('is_open', false)
							item.$callMethod('oepnOrClose', false)
						}
					})
				}
			}
		}
	}
</script>

<style>

</style>