- 引入
- 代码演示
- 基本
- 使用插槽及其他配置
- API
- Cashier Props
- Cashier Methods
- next(scene, option)
- Captcha Slots
- header
- footer
- channel
- payButton
- scene
- Cashier Events
- @select(item: {text, value})
- @pay(item: {text, value})
- @cancel()
- @show()
- @hide()
Cashier 收银台

业务支付弹窗,支持支付渠道选择和支付验证码发送
引入
import { Cashier } from 'mand-mobile'Vue.component(Cashier.name, Cashier)
代码演示
基本

<template><div class="md-example-child md-example-child-cashier"><md-fieldtitle="支付结果"><md-radio-listv-model="cashierResult":options="cashierResults"/></md-field><md-fieldtitle="支付配置"><md-input-itemtitle="支付金额"align="right"type="money"v-model="cashierAmount"></md-input-item><md-field-itemtitle="发送验证码"align="right"><md-switch v-model="isCashierCaptcha"></md-switch></md-field-item></md-field><md-button @click="isCashierhow = !isCashierhow">{{ isCashierhow ? '收起收银台' : '唤起收银台' }}</md-button><md-cashierref="cashier"v-model="isCashierhow":channels="cashierChannels":channel-limit="2":payment-amount="cashierAmount"payment-describe="关于支付金额的特殊说明"large-radius@select="onCashierSelect"@pay="onCashierPay"@cancel="onCashierCancel"></md-cashier></div></template><script>import {Button, RadioList, Field, FieldItem, InputItem, Switch, Cashier, Toast} from 'mand-mobile'export default {name: 'cashier-demo',components: {[Button.name]: Button,[RadioList.name]: RadioList,[Field.name]: Field,[FieldItem.name]: FieldItem,[InputItem.name]: InputItem,[Switch.name]: Switch,[Cashier.name]: Cashier,},data() {return {isCashierhow: false,isCashierCaptcha: false,cashierAmount: '100.00',cashierResult: 'success',cashierResults: [{text: '支付成功',value: 'success',},{text: '支付失败',value: 'fail',},],cashierChannels: [{icon: 'cashier-icon-1',text: '招商银行(0056)',value: '001',},{icon: 'cashier-icon-2',text: '支付宝支付',value: '002',},{icon: 'cashier-icon-3',text: '微信支付',value: '003',},{icon: 'cashier-icon-4',text: 'QQ钱包支付',value: '004',},{icon: 'cashier-icon-5',text: '一网通支付',value: '005',},],}},computed: {cashier() {return this.$refs.cashier},},methods: {doPay() {if (this.isCashierCaptcha) {this.cashier.next('captcha', {text: 'Verification code sent to 156 **** 8965',brief: 'The latest verification code is still valid',autoCountdown: false,countNormalText: 'Send Verification code',countActiveText: 'Retransmission after {$1}s',onSend: countdown => {console.log('[Mand Mobile] Send Captcha')this.sendCaptcha().then(() => {countdown()})},onSubmit: code => {console.log(`[Mand Mobile] Send Submit ${code}`)this.checkCaptcha(code).then(res => {if (res) {this.createPay().then(() => {this.cashier.next(this.cashierResult)})}})},})} else {this.createPay().then(() => {this.cashier.next(this.cashierResult, {buttonText: '好的',handler: () => {this.isCashierhow = falseToast.info(`${this.cashierResult}点击`)},})})}},// Create a pay request & check pay resultcreatePay() {this.cashier.next('loading')return new Promise(resolve => {this.timer = setTimeout(() => {resolve()}, 3000)})},// Create a captcha sending requestsendCaptcha() {return new Promise(resolve => {this.timer = setTimeout(() => {resolve()}, 200)})},// Create a captcha checking requestcheckCaptcha(code) {return new Promise(resolve => {this.timer = setTimeout(() => {resolve(!!code)}, 200)})},onCashierSelect(item) {console.log(`[Mand Mobile] Select ${JSON.stringify(item)}`)},onCashierPay(item) {console.log(`[Mand Mobile] Pay ${JSON.stringify(item)}`)this.doPay()},onCashierCancel() {// Abort pay request or checking requestthis.timer && clearTimeout(this.timer)},},}</script><style lang="stylus">.md-example-child-cashier.md-fieldmargin-bottom 30px.md-cashier-channel-item.item-icon.cashier-icon-1background url('') center no-repeatbackground-size 26px.item-icon.cashier-icon-2background url('') center no-repeatbackground-size 26px.item-icon.cashier-icon-3background url('') center no-repeatbackground-size 26px.item-icon.cashier-icon-4background url('') center no-repeatbackground-size 26px.item-icon.cashier-icon-5background url('') center no-repeatbackground-size 26px</style>
使用插槽及其他配置

<template>
<div class="md-example-child md-example-child-cashier">
<md-button @click="isCashierhow = !isCashierhow">{{ isCashierhow ? '收起收银台' : '唤起收银台' }}</md-button>
<md-cashier
ref="cashier"
v-model="isCashierhow"
:channels="cashierChannels"
:payment-amount="cashierAmount"
payment-describe="关于支付金额的特殊说明"
large-radius
@show="onCashierShow"
@select="onCashierSelect"
@pay="onCashierPay"
@cancel="onCashierCancel"
>
<div slot-scope="{ scene }" slot="header">
<md-notice-bar
v-if="scene === 'choose'"
mode="closable"
icon="warn"
type="warning"
>
该银行3:00-12:00系统维护,请更换其他银行卡
</md-notice-bar>
</div>
<div slot-scope="{ scene }" slot="footer">
<div v-if="scene === 'choose' && !isCashierInitialed" class="cashier-loading">
<md-activity-indicator :size="30" vertical>加载中...</md-activity-indicator>
</div>
</div>
<div slot="payButton" style="display:flex;">
<md-icon name="checked"></md-icon>发起支付
</div>
<div slot="scene" class="custom-scene">
Custom Scene
</div>
</md-cashier>
</div>
</template>
<script>
import {Button, Icon, Cashier, Toast, NoticeBar, ActivityIndicator} from 'mand-mobile'
export default {
name: 'cashier-demo',
components: {
[Button.name]: Button,
[Cashier.name]: Cashier,
[Icon.name]: Icon,
[NoticeBar.name]: NoticeBar,
[ActivityIndicator.name]: ActivityIndicator,
},
data() {
return {
isCashierhow: false,
isCashierInitialed: false,
isCashierCaptcha: false,
cashierAmount: '100.00',
cashierResult: 'success',
cashierResults: [
{
text: '支付成功',
value: 'success',
},
{
text: '支付失败',
value: 'fail',
},
],
cashierChannels: [
{
img: 'https://pt-starimg.didistatic.com/static/starimg/img/rZBbFoIJEJ1546934427562.png',
text: 'XX银行(1234)',
desc: '当前银行维护中',
value: '001',
disabled: true,
action: {
text: '更换',
handler: () => {
Toast.info('点击更换银行卡')
},
},
},
],
}
},
computed: {
cashier() {
return this.$refs.cashier
},
},
methods: {
doPay() {
if (this.isCashierCaptcha) {
this.cashier.next('captcha', {
text: 'Verification code sent to 156 **** 8965',
autoCountdown: false,
countNormalText: 'Send Verification code',
countActiveText: 'Retransmission after {$1}s',
onSend: countdown => {
console.log('[Mand Mobile] Send Captcha')
this.sendCaptcha().then(() => {
countdown()
})
},
onSubmit: code => {
console.log(`[Mand Mobile] Send Submit ${code}`)
this.checkCaptcha(code).then(res => {
if (res) {
this.createPay().then(() => {
this.cashier.next(this.cashierResult)
})
}
})
},
})
} else {
this.createPay().then(() => {
this.cashier.next(this.cashierResult, {
actions: [
{
buttonText: '返回',
handler: () => {
this.cashier.next('choose')
},
},
{
buttonText: '重试',
handler: () => {
this.cashier.next('custom')
},
},
],
})
})
}
},
// Create a pay request & check pay result
createPay() {
this.cashier.next('loading')
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve()
}, 3000)
})
},
// Create a captcha sending request
sendCaptcha() {
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve()
}, 200)
})
},
// Create a captcha checking request
checkCaptcha(code) {
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve(!!code)
}, 200)
})
},
onCashierShow() {
setTimeout(() => {
this.isCashierInitialed = true
}, 2000)
},
onCashierSelect(item) {
console.log(`[Mand Mobile] Select ${JSON.stringify(item)}`)
},
onCashierPay(item) {
console.log(`[Mand Mobile] Pay ${JSON.stringify(item)}`)
this.doPay()
},
onCashierCancel() {
// Abort pay request or checking request
this.timer && clearTimeout(this.timer)
},
},
}
</script>
<style lang="stylus">
.md-example-child-cashier
.md-field
margin-bottom 30px
.custom-scene
min-height 300px
display flex
justify-content center
align-items center
font-size 32px
.cashier-loading
position absolute
top 0
left 0
right 0
bottom 0
background rgba(255, 255, 255, 0.95)
z-index 1400
display flex
align-items center
justify-content center
</style>
API
Cashier Props
| 属性 | 说明 | 类型 | 默认值 | 备注 |
|---|---|---|---|---|
| v-model | 收银台是否显示 | Boolean | false | - |
| channels | 支付渠道数据源 | Array<{text, value, icon, iconSvg, img, action}> | [] | icon可作为className或组件Icon的name属性, iconSvg为是否使用svg图标, img为图标链接(与icon二选一), action为特殊动作回调 |
| channel-limit | 支付渠道超出限制数目时展示更多支付渠道按钮 | Number | 2 | - |
| default-index | 默认选中支付渠道索引 | Number | 0 | - |
| title | 收银台弹窗标题 | String | 支付 | - |
| large-radius 2.4.0+ | 选择器标题栏大圆角模式 | Boolean | false | - |
| payment-title | 支付金额标题 | String | 支付金额(元) | 支持html fragment |
| payment-amount | 支付金额 | String | 0.00 | 支持html fragment |
| payment-describe | 支付金额说明 | String | - | 支持html fragment |
| pay-button-text | 确认支付按钮文案 | String | 确认支付 | - |
| pay-button-disabled | 禁用支付按钮 | Boolean | false | - |
| more-button-text | 更多支付渠道按钮文案 | String | 更多支付方式 | 支持html fragment |
Cashier Methods
next(scene, option)
进入收银台下一步
| 参数 | 说明 | 类型 | 默认值 | 备注 |
|---|---|---|---|---|
| scene | 步骤场景标识 | String | - | choose(支付渠道选择)captcha(发送验证码)loading(支付中)success(支付成功)fail(支付失败)custom(自定义,使用插槽scene填充内容) |
| option | 当前步骤场景配置 | Object | 属性如下所示 | - |
captchaoption属性 说明 类型 默认值 备注 text 发送验证码说明 String - - brief 发送验证码简要描述 String - - maxlength 验证码位数 Number 4若为 -1则不限制输入长度count 验证码重新发送倒计时 Number 60若为 0则不显示重新发送autoCountdown 是否自动开始倒计时,否则需手动调用 countdownBoolean true- countNormalText 发送验证码正常状态文字 String 发送验证码- countActiveText 发送验证码及倒计时按钮文案配置项 String {$1}秒后重发- onSend 验证码发送回调 Function(countdown: Function) - countdown为开始倒计时方法onSubmit 验证码提交回调 Function(code: String) - code为输入的验证码loadingoption属性 说明 类型 默认值 备注 text 支付中说明 String 支付结果查询中…支持 html fragmentsuccessoption属性 说明 类型 默认值 备注 text 支付成功说明 String 支付成功支持 html fragmentbuttonText 按钮文案 String 我知道了支持 html fragmenthandler 按钮点击回调 Function - - actions 按钮组 Array<{buttonText, handler}> - 有两个按钮时使用 failoption属性 说明 类型 默认值 备注 text 支付失败说明 String 支付失败,请稍后重试支持 html fragmentbuttonText 按钮文案 String 我知道了支持 html fragmenthandler 按钮点击回调 Function - - actions 按钮组 Array<{buttonText, handler}> - 有两个按钮时使用
Captcha Slots
header
头部内容scoped插槽
<div slot-scope="{ scene }" slot="header">
<md-notice-bar
v-if="scene === 'choose'"
mode="closable"
icon="warn"
type="warning"
></md-notice-bar>
</div>
footer
底部内容scoped插槽
channel
支付渠道区域插槽,可用于添加支付渠道特殊操作,如添加银行卡
payButton
发起支付插槽
scene
自定义场景插槽,使用next('custom')打开
Cashier Events
@select(item: {text, value})
支付渠道选中事件
@pay(item: {text, value})
支付渠道确认并发起支付事件
@cancel()
取消支付事件
@show()
收银台弹窗展示事件
@hide()
收银台弹窗隐藏事件
