import { VantComponent } from '../common/component'; VantComponent({ relation: { name: 'collapse-item', type: 'descendant', linked(child) { this.children.push(child); }, unlinked(child) { this.children = this.children.filter((item) => item !== child); } }, props: { value: { type: null, observer: 'updateExpanded' }, accordion: { type: Boolean, observer: 'updateExpanded' }, border: { type: Boolean, value: true } }, beforeCreate() { this.children = []; }, methods: { updateExpanded() { this.children.forEach((child) => { child.updateExpanded(); }); }, switch(name, expanded) { const { accordion, value } = this.data; if (!accordion) { name = expanded ? (value || []).concat(name) : (value || []).filter((activeName) => activeName !== name); } else { name = expanded ? name : ''; } this.$emit('change', name); this.$emit('input', name); } } });