# Contact ### Install ``` javascript import { ContactCard, ContactList, ContactEdit } from 'vant'; Vue .use(ContactCard) .use(ContactList) .use(ContactEdit); ``` ## Usage ### Basic Usage ```html ``` ``` javascript export default { data() { return { chosenContactId: null, editingContact: {}, showList: false, showEdit: false, isEdit: false, list: [{ name: 'John Snow', tel: '13000000000', id: 0 }] }; }, computed: { cardType() { return this.chosenContactId !== null ? 'edit' : 'add'; }, currentContact() { const id = this.chosenContactId; return id !== null ? this.list.filter(item => item.id === id)[0] : {}; } }, methods: { // add contact onAdd() { this.editingContact = { id: this.list.length }; this.isEdit = false; this.showEdit = true; }, // edit contact onEdit(item) { this.isEdit = true; this.showEdit = true; this.editingContact = item; }, // select contact onSelect() { this.showList = false; }, // save contact onSave(info) { this.showEdit = false; this.showList = false; if (this.isEdit) { this.list = this.list.map(item => item.id === info.id ? info : item); } else { this.list.push(info); } this.chosenContactId = info.id; }, // delete contact onDelete(info) { this.showEdit = false; this.list = this.list.filter(item => item.id !== info.id); if (this.chosenContactId === info.id) { this.chosenContactId = null; } } } }; ``` ### Uneditable ```html ``` ## API ### ContactCard Props | Attribute | Description | Type | Default | |------|------|------|------| | type | Can be set to `add` `edit` | `String` | `add` | | name | Name | `String` | - | | tel | Phone | `String` | - | | add-text | Add card text | `String` | `Add contact info` | ### ContactCard Events | Event | Description | Arguments | |------|------|------| | click | Triggered when clicked | - | ### ContactList Props | Attribute | Description | Type | Default | |------|------|------|------|------| | v-model | Id of chosen contact | `String | Number` | - | | list | Contact list | `Array` | `[]` | | add-text | Add button text | `String` | `Add new contact` | ### ContactList Events | Event | Description | Arguments | |------|------|------| | add | Triggered when click add button | - | | edit | Triggered when click edit button | item: contact object,index | | select | Triggered when select contact | item: contact object | ### ContactEdit Props | Attribute | Description | Type | Default | |------|------|------|------|------| | contact-info | Contact Info | `Object` | `[]` | | is-edit | Whether is editing | `Boolean` | `false` | | is-saving | Whether to show save button loading status | `Boolean` | `false` | | is-deleting | Whether to show delete button loading status | `Boolean` | `false` | | tel-validator | The method to validate tel | `(tel: string) => boolean` | - | ### ContactEdit Events | Event | Description | Arguments | |------|------|------| | save | Triggered when click save button | content:contact info | | delete | Triggered when click delete button | content:contact info | ### Contact Data Structure | key | Description | Type | |------|------|------| | id | ID | `String | Number` | | name | Name | `String` | | tel | Phone | `String` |