107 lines
3.1 KiB
Markdown
107 lines
3.1 KiB
Markdown
|
|
# ContactEdit 联系人编辑
|
|||
|
|
|
|||
|
|
### 介绍
|
|||
|
|
|
|||
|
|
编辑并保存联系人信息。
|
|||
|
|
|
|||
|
|
### 引入
|
|||
|
|
|
|||
|
|
通过以下方式来全局注册组件,更多注册方式请参考[组件注册](#/zh-CN/advanced-usage#zu-jian-zhu-ce)。
|
|||
|
|
|
|||
|
|
```js
|
|||
|
|
import { createApp } from 'vue';
|
|||
|
|
import { ContactEdit } from 'vant';
|
|||
|
|
|
|||
|
|
const app = createApp();
|
|||
|
|
app.use(ContactEdit);
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 代码演示
|
|||
|
|
|
|||
|
|
### 基础用法
|
|||
|
|
|
|||
|
|
```html
|
|||
|
|
<van-contact-edit
|
|||
|
|
is-edit
|
|||
|
|
show-set-default
|
|||
|
|
:contact-info="editingContact"
|
|||
|
|
set-default-label="设为默认联系人"
|
|||
|
|
@save="onSave"
|
|||
|
|
@delete="onDelete"
|
|||
|
|
/>
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
```js
|
|||
|
|
import { ref } from 'vue';
|
|||
|
|
import { showToast } from 'vant';
|
|||
|
|
|
|||
|
|
export default {
|
|||
|
|
setup() {
|
|||
|
|
const editingContact = ref({
|
|||
|
|
tel: '',
|
|||
|
|
name: '',
|
|||
|
|
});
|
|||
|
|
const onSave = (contactInfo) => showToast('保存');
|
|||
|
|
const onDelete = (contactInfo) => showToast('删除');
|
|||
|
|
return {
|
|||
|
|
onSave,
|
|||
|
|
onDelete,
|
|||
|
|
editingContact,
|
|||
|
|
};
|
|||
|
|
},
|
|||
|
|
};
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## API
|
|||
|
|
|
|||
|
|
### Props
|
|||
|
|
|
|||
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|||
|
|
| --- | --- | --- | --- |
|
|||
|
|
| contact-info | 联系人信息 | _ContactEditInfo_ | `{}` |
|
|||
|
|
| is-edit | 是否为编辑联系人 | _boolean_ | `false` |
|
|||
|
|
| is-saving | 是否显示保存按钮加载动画 | _boolean_ | `false` |
|
|||
|
|
| is-deleting | 是否显示删除按钮加载动画 | _boolean_ | `false` |
|
|||
|
|
| tel-validator | 手机号格式校验函数 | _(tel: string) => boolean_ | - |
|
|||
|
|
| show-set-default | 是否显示默认联系人栏 | _boolean_ | `false` |
|
|||
|
|
| set-default-label | 默认联系人栏文案 | _string_ | - |
|
|||
|
|
|
|||
|
|
### Events
|
|||
|
|
|
|||
|
|
| 事件名 | 说明 | 回调参数 |
|
|||
|
|
| -------------- | -------------------------- | ----------------- |
|
|||
|
|
| save | 点击保存按钮时触发 | content:表单内容 |
|
|||
|
|
| delete | 点击删除按钮时触发 | content:表单内容 |
|
|||
|
|
| change-default | 切换是否为默认联系人时触发 | checked:是否默认 |
|
|||
|
|
|
|||
|
|
### ContactEditInfo 数据结构
|
|||
|
|
|
|||
|
|
| 键名 | 说明 | 类型 |
|
|||
|
|
| --------- | ------------ | ---------------------- |
|
|||
|
|
| name | 联系人姓名 | _string_ |
|
|||
|
|
| tel | 联系人手机号 | _string_ |
|
|||
|
|
| isDefault | 是否默认 | _boolean \| undefined_ |
|
|||
|
|
|
|||
|
|
### 类型定义
|
|||
|
|
|
|||
|
|
组件导出以下类型定义:
|
|||
|
|
|
|||
|
|
```ts
|
|||
|
|
import type { ContactEditInfo, ContactEditProps } from 'vant';
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 主题定制
|
|||
|
|
|
|||
|
|
### 样式变量
|
|||
|
|
|
|||
|
|
组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 [ConfigProvider 组件](#/zh-CN/config-provider)。
|
|||
|
|
|
|||
|
|
| 名称 | 默认值 | 描述 |
|
|||
|
|
| --------------------------------------- | ------------------------- | ---- |
|
|||
|
|
| --van-contact-edit-padding | _var(--van-padding-md)_ | - |
|
|||
|
|
| --van-contact-edit-fields-radius | _var(--van-radius-md)_ | - |
|
|||
|
|
| --van-contact-edit-buttons-padding | _var(--van-padding-xl) 0_ | - |
|
|||
|
|
| --van-contact-edit-button-margin-bottom | _var(--van-padding-sm)_ | - |
|
|||
|
|
| --van-contact-edit-button-font-size | _var(--van-font-size-lg)_ | - |
|
|||
|
|
| --van-contact-edit-field-label-width | _4.1em_ | - |
|