vant/src/contact-list

ContactList

Install

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

Vue.use(ContactList);

Usage

Basic Usage

<van-contact-list
  v-model="chosenContactId"
  :list="list"
  default-tag-text="default"
  @add="onAdd"
  @edit="onEdit"
  @select="onSelect"
/>
import { Toast } from 'vant';

export default {
  data() {
    return {
      chosenContactId: '1',
      list: [
        {
          id: '1',
          name: 'John Snow',
          tel: '13000000000',
          isDefault: true,
        },
        {
          id: '2',
          name: 'Ned Stark',
          tel: '1310000000',
        },
      ],
    };
  },
  methods: {
    onAdd() {
      Toast('Add');
    },
    onEdit(contact) {
      Toast('Edit' + contact.id);
    },
    onSelect(contact) {
      Toast('Select' + contact.id);
    },
  },
};

API

Props

Attribute Description Type Default
v-model Id of chosen contact number | string -
list Contact list Contact[] []
add-text Add button text string Add new contact
default-tag-text Default tag text string -

Events

Event Description Arguments
add Emitted when the add button is clicked -
edit Emitted when the edit button is clicked contact: Contactindex: number
select Emitted when a contact is selected contact: Contact, index: number

Data Structure of Contact

key Description Type
id ID number | string
name Name string
tel Phone string
isDefault Is default contact boolean

Less Variables

How to use: Custom Theme.

Name Default Value Description
@contact-list-edit-icon-size 16px -
@contact-list-add-button-z-index 999 -
@contact-list-item-padding @padding-md -