128 lines
3.2 KiB
Vue
128 lines
3.2 KiB
Vue
<template>
|
||
<view class="u-drawdown">
|
||
<view
|
||
class="u-dropdown__menu"
|
||
:style="{
|
||
height: $u.addUnit(height)
|
||
}"
|
||
ref="u-dropdown__menu"
|
||
>
|
||
<view
|
||
class="u-dropdown__menu__item"
|
||
v-for="(item, index) in menuList"
|
||
:key="index"
|
||
@tap.stop="clickHandler(item, index)"
|
||
>
|
||
<view class="u-dropdown__menu__item__content">
|
||
<text
|
||
class="u-dropdown__menu__item__content__text"
|
||
:style="[index === current ? activeStyle : inactiveStyle]"
|
||
>{{item.title}}</text>
|
||
<view
|
||
class="u-dropdown__menu__item__content__arrow"
|
||
:class="[index === current && 'u-dropdown__menu__item__content__arrow--rotate']"
|
||
>
|
||
<u-icon
|
||
:name="menuIcon"
|
||
:size="$u.addUnit(menuIconSize)"
|
||
></u-icon>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="u-dropdown__content">
|
||
<slot />
|
||
</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import props from './props.js';
|
||
/**
|
||
* Dropdown
|
||
* @description
|
||
* @tutorial url
|
||
* @property {String}
|
||
* @event {Function}
|
||
* @example
|
||
*/
|
||
export default {
|
||
name: 'u-dropdown',
|
||
mixins: [uni.$u.mixin, props],
|
||
data() {
|
||
return {
|
||
// �˵�����
|
||
menuList: [],
|
||
current: 0
|
||
}
|
||
},
|
||
computed: {
|
||
|
||
},
|
||
created() {
|
||
// �������������(u-dropdown-item)��this��������data��������������������С��������ѭ�����ö�����
|
||
this.children = [];
|
||
},
|
||
methods: {
|
||
clickHandler(item, index) {
|
||
this.children.map(child => {
|
||
if(child.title === item.title) {
|
||
// this.queryRect('u-dropdown__menu').then(size => {
|
||
child.$emit('click')
|
||
child.setContentAnimate(child.show ? 0 : 300)
|
||
child.show = !child.show
|
||
// })
|
||
} else {
|
||
child.show = false
|
||
child.setContentAnimate(0)
|
||
}
|
||
})
|
||
},
|
||
// ��ȡ��ǩ�ijߴ�λ��
|
||
queryRect(el) {
|
||
// #ifndef APP-NVUE
|
||
// $uGetRectΪuView�Դ��Ľڵ��ѯ����������ĵ����ܣ�https://www.uviewui.com/js/getRect.html
|
||
// ����ڲ�һ����this.$uGetRect�������Ϊthis.$u.getRect�����߹���һ�£����Ʋ�ͬ
|
||
return new Promise(resolve => {
|
||
this.$uGetRect(`.${el}`).then(size => {
|
||
resolve(size)
|
||
})
|
||
})
|
||
// #endif
|
||
|
||
// #ifdef APP-NVUE
|
||
// nvue�£�ʹ��domģ���ѯԪ�ظ߶�
|
||
// ����һ��promise���õ��ô˷�����������ʹ��then�ص�
|
||
return new Promise(resolve => {
|
||
dom.getComponentRect(this.$refs[el], res => {
|
||
resolve(res.size)
|
||
})
|
||
})
|
||
// #endif
|
||
},
|
||
},
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss">
|
||
@import '../../libs/css/components.scss';
|
||
|
||
.u-dropdown {
|
||
|
||
&__menu {
|
||
@include flex;
|
||
|
||
&__item {
|
||
flex: 1;
|
||
@include flex;
|
||
justify-content: center;
|
||
|
||
&__content {
|
||
@include flex;
|
||
align-items: center;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
</style>
|