Categories: Vant4 教程

Vant4 AddressList 地址列表

介绍

展示地址信息列表。

引入

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

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 当前选中地址的 id string
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-padding var(–van-padding-sm) var(–van-padding-sm) 80px
–van-address-list-disabled-text-color var(–van-text-color-2)
–van-address-list-disabled-text-padding var(–van-padding-base) * 5 0 var(–van-padding-md)
–van-address-list-disabled-text-font-size var(–van-font-size-md)
–van-address-list-disabled-text-line-height var(–van-line-height-md)
–van-address-list-add-button-z-index 999
–van-address-list-item-padding var(–van-padding-sm)
–van-address-list-item-text-color var(–van-text-color)
–van-address-list-item-disabled-text-color var(–van-text-color-3)
–van-address-list-item-font-size 13px
–van-address-list-item-line-height var(–van-line-height-sm)
–van-address-list-radio-color var(–van-primary-color)
–van-address-list-edit-icon-size 20px
admin

这个人很懒,什么都没有留下~

Share
Published by
admin

Recent Posts

vue:页面注入js修改input值

一般会直接这样写: let z…

2 小时 ago

聊聊vue3中的defineProps

在Vue 3中,defineP…

1 周 ago

在 Chrome 中删除、允许和管理 Cookie

您可以选择删除现有 Cooki…

2 周 ago

自定义指令:聊聊vue中的自定义指令应用法则

今天我们来聊聊vue中的自定义…

3 周 ago

聊聊Vue中@click.stop和@click.prevent

一起来学下聊聊Vue中@cli…

4 周 ago

Nginx 基本操作:启动、停止、重启命令。

我们来学习Nginx基础操作:…

1 月 ago