¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <view class="uni-collapse"> |
| | | <slot /> |
| | | </view> |
| | | </template> |
| | | <script> |
| | | /** |
| | | * Collapse æå 颿¿ |
| | | * @description å±ç¤ºå¯ä»¥æå / å±å¼çå
容åºå |
| | | * @tutorial https://ext.dcloud.net.cn/plugin?id=23 |
| | | * @property {String|Array} value å½åæ¿æ´»é¢æ¿æ¹åæ¶è§¦å(å¦ææ¯æé£ç´æ¨¡å¼ï¼åæ°ç±»å为stringï¼å¦å为array) |
| | | * @property {Boolean} accordion = [true|false] æ¯å¦å¼å¯æé£ç´æææ¯å¦å¼å¯æé£ç´ææ |
| | | * @event {Function} change 忢颿¿æ¶è§¦åï¼å¦ææ¯æé£ç´æ¨¡å¼ï¼è¿åç±»å为stringï¼å¦å为array |
| | | */ |
| | | export default { |
| | | name: 'uniCollapse', |
| | | emits:['change','activeItem','input','update:modelValue'], |
| | | props: { |
| | | value: { |
| | | type: [String, Array], |
| | | default: '' |
| | | }, |
| | | modelValue: { |
| | | type: [String, Array], |
| | | default: '' |
| | | }, |
| | | accordion: { |
| | | // æ¯å¦å¼å¯æé£ç´ææ |
| | | type: [Boolean, String], |
| | | default: false |
| | | }, |
| | | }, |
| | | data() { |
| | | return {} |
| | | }, |
| | | computed: { |
| | | // TODO å
¼å®¹ vue2 å vue3 |
| | | dataValue() { |
| | | let value = (typeof this.value === 'string' && this.value === '') || |
| | | (Array.isArray(this.value) && this.value.length === 0) |
| | | let modelValue = (typeof this.modelValue === 'string' && this.modelValue === '') || |
| | | (Array.isArray(this.modelValue) && this.modelValue.length === 0) |
| | | if (value) { |
| | | return this.modelValue |
| | | } |
| | | if (modelValue) { |
| | | return this.value |
| | | } |
| | | |
| | | return this.value |
| | | } |
| | | }, |
| | | watch: { |
| | | dataValue(val) { |
| | | this.setOpen(val) |
| | | } |
| | | }, |
| | | created() { |
| | | this.childrens = [] |
| | | this.names = [] |
| | | }, |
| | | mounted() { |
| | | this.$nextTick(()=>{ |
| | | this.setOpen(this.dataValue) |
| | | }) |
| | | }, |
| | | methods: { |
| | | setOpen(val) { |
| | | let str = typeof val === 'string' |
| | | let arr = Array.isArray(val) |
| | | this.childrens.forEach((vm, index) => { |
| | | if (str) { |
| | | if (val === vm.nameSync) { |
| | | if (!this.accordion) { |
| | | console.warn('accordion 屿§ä¸º false ,v-model ç±»ååºè¯¥ä¸º array') |
| | | return |
| | | } |
| | | vm.isOpen = true |
| | | } |
| | | } |
| | | if (arr) { |
| | | val.forEach(v => { |
| | | if (v === vm.nameSync) { |
| | | if (this.accordion) { |
| | | console.warn('accordion 屿§ä¸º true ,v-model ç±»ååºè¯¥ä¸º string') |
| | | return |
| | | } |
| | | vm.isOpen = true |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | this.emit(val) |
| | | }, |
| | | setAccordion(self) { |
| | | if (!this.accordion) return |
| | | this.childrens.forEach((vm, index) => { |
| | | if (self !== vm) { |
| | | vm.isOpen = false |
| | | } |
| | | }) |
| | | }, |
| | | resize() { |
| | | this.childrens.forEach((vm, index) => { |
| | | // #ifndef APP-NVUE |
| | | vm.getCollapseHeight() |
| | | // #endif |
| | | // #ifdef APP-NVUE |
| | | vm.getNvueHwight() |
| | | // #endif |
| | | }) |
| | | }, |
| | | onChange(isOpen, self) { |
| | | let activeItem = [] |
| | | |
| | | if (this.accordion) { |
| | | activeItem = isOpen ? self.nameSync : '' |
| | | } else { |
| | | this.childrens.forEach((vm, index) => { |
| | | if (vm.isOpen) { |
| | | activeItem.push(vm.nameSync) |
| | | } |
| | | }) |
| | | } |
| | | this.$emit('change', activeItem) |
| | | this.emit(activeItem) |
| | | }, |
| | | emit(val){ |
| | | this.$emit('input', val) |
| | | this.$emit('update:modelValue', val) |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | <style lang="scss" > |
| | | .uni-collapse { |
| | | /* #ifndef APP-NVUE */ |
| | | width: 100%; |
| | | display: flex; |
| | | /* #endif */ |
| | | /* #ifdef APP-NVUE */ |
| | | flex: 1; |
| | | /* #endif */ |
| | | flex-direction: column; |
| | | background-color: #fff; |
| | | } |
| | | </style> |