PickerItem 选择输入
选择输入。
扫码体验
示例代码
// API-DEMO page/component/input-item/input-item.json
{
"defaultTitle": "小程序AntUI组件库",
"usingComponents": {
"list": "mini-antui/es/list/index",
"list-item": "mini-antui/es/list/list-item/index",
"input-item": "mini-antui/es/input-item/index",
"picker-item": "mini-antui/es/picker-item/index"
}
}
<!-- API-DEMO page/component/input-item/input-item.axml -->
<view>
<view style="margin-top: 10px;" />
<list>
<input-item
data-field="cardNo"
clear="{{true}}"
value="{{cardNo}}"
className="dadada"
placeholder="银行卡号"
focus="{{inputFocus}}"
onInput="onItemInput"
onFocus="onItemFocus"
onBlur="onItemBlur"
onConfirm="onItemConfirm"
onClear="onClear"
>
卡号
<view slot="extra" class="extra" onTap="onExtraTap"></view>
</input-item>
<picker-item
data-field="bank"
placeholder="选择发卡银行"
value="{{bank}}"
onPickerTap="onPickerTap"
>
发卡银行
</picker-item>
<input-item
data-field="name"
placeholder="姓名"
type="text"
value="{{name}}"
clear="{{true}}"
onInput="onItemInput"
onClear="onClear"
>
姓名
</input-item>
<input-item
data-field="password"
placeholder="密码"
password
>
密码
</input-item>
<input-item
data-field="remark"
placeholder="备注"
last="{{true}}"
/>
</list>
<view style="margin: 10px;">
<button type="primary" onTap="onAutoFocus">聚焦</button>
</view>
</view>
// API-DEMO page/component/input-item/input-item.js
const banks = ['网商银行', '建设银行', '工商银行', '浦发银行'];
Page({
data: {
cardNo: '1234****',
inputFocus: true,
bank: '',
name: '',
},
onAutoFocus() {
this.setData({
inputFocus: true,
});
},
onExtraTap() {
my.alert({
content: 'extra tapped',
});
},
onItemInput(e) {
this.setData({
[e.target.dataset.field]: e.detail.value,
});
},
onItemFocus() {
this.setData({
inputFocus: false,
});
},
onItemBlur() {},
onItemConfirm() {},
onClear(e) {
this.setData({
[e.target.dataset.field]: '',
});
},
onPickerTap() {
my.showActionSheet({
title: '选择发卡银行',
items: banks,
success: (res) => {
this.setData({
bank: banks[res.index],
});
},
});
},
});
/* API-DEMO page/component/input-item/input-item.acss */
.extra {
background-image: url('https://gw.alipayobjects.com/zos/rmsportal/dOfSJfWQvYdvsZiJStvg.svg');
background-size: contain;
background-repeat: no-repeat;
background-position: right center;
opacity: 0.2;
height: 20px;
width: 20px;
padding-left: 10px;
}
属性
属性名 | 描述 | 类型 | 默认值 |
className | 自定义的 class。 | String | - |
labelCls | 自定义 label 的class。 | String | - |
pickerCls | 自定义选择区域的 class。 | String | - |
last | 是否最后一行。 | Boolean | false |
value | 初始内容。 | String | - |
name | 组件名字,用于表单提交获取数据。 | String | - |
placeholder | 占位符。 | String | - |
onPickerTap | 点击 pickeritem 时触发。 | (e: Object) => void | - |
slots
slotname | 说明 | 必填 |
extra | 用于渲染 picker-item 项右边说明。 | 否 |