引入

import Vue from 'vue';
import { AddressList } from 'vant';

Vue.use(AddressList);

代码演示

基础用法

<van-address-list
  v-model="chosenAddressId"
  :list="list"
  :disabled-list="disabledList"
  disabled-text="以下地址超出配送范围"
  default-tag-text="默认"
  @add="onAdd"
  @edit="onEdit"
/>
import { Toast } from 'vant';

export default {
  data() {
    return {
      chosenAddressId: '1',
      list: [
        {
          id: '1',
          name: '张三',
          tel: '13000000000',
          address: '浙江省杭州市西湖区文三路 138 号东方通信大厦 7 楼 501 室'
        },
        {
          id: '2',
          name: '李四',
          tel: '1310000000',
          address: '浙江省杭州市拱墅区莫干山路 50 号'
        }
      ],
      disabledList: [
        {
          id: '3',
          name: '王五',
          tel: '1320000000',
          address: '浙江省杭州市滨江区江南大道 15 号'
        }
      ]
    }
  },
  methods: {
    onAdd() {
      Toast('新增地址');
    },
    onEdit(item, index) {
      Toast('编辑地址:' + index);
    }
  }
}

API

Props

v-model当前选中地址的 idstring-
list地址列表Address[][]
disabled-list不可配送地址列表Address[][]
disabled-text不可配送提示文案string-
switchable是否允许切换地址booleantrue
add-button-text底部按钮文字string新增地址
default-tag-text v2.3.0默认地址标签文字string-

Events

add点击新增按钮时触发-
edit点击编辑按钮时触发item: 地址对象,index: 索引
select切换选中的地址时触发item: 地址对象,index: 索引
edit-disabled编辑不可配送的地址时触发item: 地址对象,index: 索引
select-disabled选中不可配送的地址时触发item: 地址对象,index: 索引
click-item点击任意地址时触发item: 地址对象,index: 索引

Address 数据结构

id每条地址的唯一标识number | string
name收货人姓名string
tel收货人手机号number | string
address收货地址string
isDefault是否为默认地址boolean

Slots

default在列表下方插入内容
top在顶部插入内容


实例演示

07-05 08:07