1 Star 0 Fork 0

顺其自然/v-element

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
Collapse.vue 1.28 KB
一键复制 编辑 原始数据 按行查看 历史
顺其自然 提交于 2024-01-19 14:42 +08:00 . feat: 初始化
<template>
<div
class="vk-collapse"
>
<slot/>
</div>
</template>
<script setup lang="ts">
import { ref, provide, watch } from 'vue'
import type { NameType, CollapseProps, CollapseEmits } from './types'
import { collapseContextKey } from './types'
defineOptions({
name: 'TmCollapse'
})
const props = defineProps<CollapseProps>()
const emits = defineEmits<CollapseEmits>()
const activeNames = ref<NameType[]>(props.modelValue)
watch(() => props.modelValue, () => {
activeNames.value = props.modelValue
})
if (props.accordion && activeNames.value.length > 1) {
console.warn('accordion mode should only have one acitve item')
}
const handleItemClick = (item: NameType) => {
let _activeNames = [...activeNames.value ]
if (props.accordion) {
_activeNames = [ activeNames.value[0] === item ? '' : item ]
activeNames.value = _activeNames
} else {
const index = _activeNames.indexOf(item)
if (index > -1) {
// 存在,删除数组对应的一项
_activeNames.splice(index, 1)
} else {
// 不存在,插入对应的name
_activeNames.push(item)
}
activeNames.value = _activeNames
}
emits('update:modelValue', _activeNames)
emits('change', _activeNames)
}
provide(collapseContextKey, {
activeNames,
handleItemClick
})
</script>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/guozhaoxi/v-element.git
git@gitee.com:guozhaoxi/v-element.git
guozhaoxi
v-element
v-element
master

搜索帮助