封装一个包含van-popup van-dropdown-menu的组件
时间: 2023-07-26 14:07:10 浏览: 112
可以使用Vue.js框架来封装一个包含van-popup和van-dropdown-menu的组件。下面是一个简单的示例代码:
```html
<template>
<div class="dropdown">
<van-popup v-model="popupVisible" position="bottom">
<van-dropdown-menu :active-color="activeColor" :options="options" @select="onSelect">
<template #title>
<span>{{ selectedOption.label }}</span>
<van-icon :name="popupVisible ? 'arrow-up' : 'arrow-down'" />
</template>
</van-dropdown-menu>
</van-popup>
</div>
</template>
<script>
import { VanPopup, VanDropdownMenu, VanIcon } from 'vant';
export default {
name: 'MyDropdown',
components: { VanPopup, VanDropdownMenu, VanIcon },
props: {
options: {
type: Array,
required: true,
},
activeColor: {
type: String,
default: '#1989fa',
},
},
data() {
return {
popupVisible: false,
selectedOption: {},
};
},
methods: {
onSelect(option) {
this.popupVisible = false;
this.selectedOption = option;
this.$emit('select', option);
},
},
};
</script>
```
在这个示例中,我们创建了一个名为`MyDropdown`的组件,它接受两个props:`options`和`activeColor`。`options`是一个由下拉选项组成的数组,`activeColor`是选中项的颜色,默认为蓝色。
组件包含一个van-popup和van-dropdown-menu,用于展示下拉选项。当用户点击下拉菜单时,van-popup将展示van-dropdown-menu,并在选择一个选项后关闭van-popup。同时,组件会触发一个`select`事件,将选中的选项传递给父组件。
这个组件可以使用以下方式在父组件中引入:
```html
<template>
<my-dropdown :options="options" @select="onSelect" />
</template>
<script>
import MyDropdown from './MyDropdown.vue';
export default {
components: { MyDropdown },
data() {
return {
options: [
{ value: 'option1', label: 'Option 1' },
{ value: 'option2', label: 'Option 2' },
{ value: 'option3', label: 'Option 3' },
],
selectedOption: {},
};
},
methods: {
onSelect(option) {
this.selectedOption = option;
console.log('Selected option:', option);
},
},
};
</script>
```
在这个示例中,我们引入了名为`MyDropdown`的组件,并传递了一个`options`数组作为props。当用户选择一个选项时,组件会触发`select`事件,并将选中的选项传递给父组件。在这里,我们将选中的选项打印到控制台上。
阅读全文