DropdownMenu 下拉菜单
引入
通过以下方式来全局注册组件,更多注册方式请参考。
基础用法
<van-dropdown-item v-model="value1" :options="option1" />
<van-dropdown-item v-model="value2" :options="option2" />
</van-dropdown-menu>
import { ref } from 'vue';
export default {
setup() {
const value1 = ref(0);
const value2 = ref('a');
const option1 = [
{ text: '新款商品', value: 1 },
{ text: '活动商品', value: 2 },
];
const option2 = [
{ text: '默认排序', value: 'a' },
{ text: '好评排序', value: 'b' },
{ text: '销量排序', value: 'c' },
];
return {
value1,
value2,
option1,
option2,
};
},
};
自定义菜单内容
通过插槽可以自定义 DropdownItem
的内容,此时需要使用实例上的 toggle
方法手动控制菜单的显示。
import { ref } from 'vue';
setup() {
const item = ref(null);
const value = ref(0);
const switch1 = ref(false);
const switch2 = ref(false);
const options = [
{ text: '全部商品', value: 0 },
{ text: '新款商品', value: 1 },
{ text: '活动商品', value: 2 },
];
const onConfirm = () => {
};
return {
item,
value,
switch1,
switch2,
options,
onConfirm,
};
},
};
自定义选中态颜色
通过 active-color
属性可以自定义菜单标题和选项的选中态颜色。
<van-dropdown-menu active-color="#1989fa">
<van-dropdown-item v-model="value1" :options="option1" />
<van-dropdown-item v-model="value2" :options="option2" />
</van-dropdown-menu>
禁用菜单
<van-dropdown-menu>
<van-dropdown-item v-model="value2" disabled :options="option2" />
</van-dropdown-menu>
DropdownMenu Props
DropdownItem Props
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
v-model | 当前选中项对应的 value | number | string | - |
title | 菜单项标题 | string | 当前选中项文字 |
options | 选项数组 | Option[] | [] |
disabled | 是否禁用菜单 | boolean | false |
lazy-render | 是否在首次展开时才渲染菜单内容 | boolean | true |
title-class | 标题额外类名 | string | Array | object | - |
teleport | 指定挂载的节点,等同于 Teleport 组件的 to 属性 | string | Element | - |
DropdownItem Events
名称 | 说明 |
---|---|
default | 菜单内容 |
title | 自定义菜单项标题 |
DropdownItem 方法
通过 ref 可以获取到 DropdownItem 实例并调用实例方法,详见。
类型定义
组件导出以下类型定义:
import type {
DropdownMenuProps,
DropdownItemProps,
DropdownItemOption,
DropdownItemInstance,
DropdownMenuDirection,
} from 'vant';
DropdownItemInstance
是组件实例的类型,用法如下:
Option 数据结构
键名 | 说明 | 类型 |
---|---|---|
text | 文字 | string |
value | 标识符 | number | string |
icon | 左侧图标名称或图片链接 | string |
样式变量
把 DropdownMenu
嵌套在 Tabs
等组件内部使用时,可能会遇到下拉菜单位置错误的问题。这是因为在 Chrome 浏览器中,transform 元素内部的 fixed 布局会降级成 absolute 布局,导致下拉菜单的布局异常。
将 DropdownItem
的 teleport
属性设置为 body
即可避免此问题:
<van-dropdown-menu>
<van-dropdown-item teleport="body" />
<van-dropdown-item teleport="body" />
</van-dropdown-menu>