Vant4 Vant4 AddressList 地址列表

2024-02-25 开发教程 Vant4 匿名 1

介绍

展示地址信息列表。

引入

通过以下方式来全局注册组件,更多注册方式请参考组件注册。

import { createApp } from 'vue';
import { AddressList } from 'vant';
const app = createApp();
app.use(AddressList);

代码演示

基础用法

<van-address-list
v-model="chosenAddressId"
:list="list"
:disabled-list="disabledList"
disabled-text="以下地址超出配送范围"
default-tag-text="默认"
@add="onAdd"
@edit="onEdit"
/>
import { ref } from 'vue';
import { showToast } from 'vant';
export default {
setup() {
const chosenAddressId = ref('1');
const list = [
{
id: '1',
name: '张三',
tel: '13000000000',
address: '浙江省杭州市西湖区文三路 138 号东方通信大厦 7 楼 501 室',
isDefault: true,
},
{
id: '2',
name: '李四',
tel: '1310000000',
address: '浙江省杭州市拱墅区莫干山路 50 号',
},
];
const disabledList = [
{
id: '3',
name: '王五',
tel: '1320000000',
address: '浙江省杭州市滨江区江南大道 15 号',
},
];
const onAdd = () => showToast('新增地址');
const onEdit = (item, index) => showToast('编辑地址:' + index);
return {
list,
onAdd,
onEdit,
disabledList,
chosenAddressId,
};
},
};

API

Props

参数说明类型默认值
v-model当前选中地址的 idstring -
list地址列表AddressListAddress[] []
disabled-list不可配送地址列表AddressListAddress[] []
disabled-text不可配送提示文案string -
switchable是否允许切换地址boolean true
add-button-text底部按钮文字string 新增地址
default-tag-text默认地址标签文字string -

Events

事件名说明回调参数
add点击新增按钮时触发-
edit点击编辑按钮时触发item: AddressListAddress, index: number
select切换选中的地址时触发item: AddressListAddress, index: number
edit-disabled编辑不可配送的地址时触发item: AddressListAddress, index: number
select-disabled选中不可配送的地址时触发item: AddressListAddress, index: number
click-item点击任意地址时触发item: AddressListAddress, index: number

AddressListAddress 数据结构

键名说明类型
id每条地址的唯一标识number | string
name姓名string
tel手机号number | string
address详细地址string
isDefault是否为默认地址boolean

Slots

名称说明参数
default在列表下方插入内容-
top在顶部插入内容-
item-bottom在列表项底部插入内容item: AddressListAddress
tag v3.0.9自定义列表项标签内容item: AddressListAddress

类型定义

组件导出以下类型定义:

import type { AddressListProps, AddressListAddress } from 'vant';

主题定制

样式变量

组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 ConfigProvider 组件。

名称默认值描述
--van-address-list-paddingvar(--van-padding-sm) var(--van-padding-sm) 80px -
--van-address-list-disabled-text-colorvar(--van-text-color-2) -
--van-address-list-disabled-text-paddingvar(--van-padding-base) * 5 0 var(--van-padding-md) -
--van-address-list-disabled-text-font-sizevar(--van-font-size-md) -
--van-address-list-disabled-text-line-heightvar(--van-line-height-md) -
--van-address-list-add-button-z-index999 -
--van-address-list-item-paddingvar(--van-padding-sm) -
--van-address-list-item-text-colorvar(--van-text-color) -
--van-address-list-item-disabled-text-colorvar(--van-text-color-3) -
--van-address-list-item-font-size13px -
--van-address-list-item-line-heightvar(--van-line-height-sm) -
--van-address-list-radio-colorvar(--van-primary-color) -
--van-address-list-edit-icon-size20px -