vue-pro/yudao-ui-app-v1/components/mix-code/mix-code.vue

114 lines
2.2 KiB
Vue

<template>
<view class="mix-get-code" @click="getCode">
<view v-if="loading" class="loading">
<mix-icon-loading size="28rpx" color="#0083ff"></mix-icon-loading>
</view>
<text class="text" :class="{disabled: timeDown > 0}">
{{ timeDown > 0 ? '重新获取 ' + timeDown + 's' : '获取验证码' }}
</text>
</view>
</template>
<script>
/**
* 手机验证码
* @prop mobile 手机号
* @prop templateCode 短信模版id
*/
import {checkStr} from '@/common/js/util'
export default {
//获取手机验证码
name: 'MixMobileCode',
data() {
return {
loading: false,
timeDown: ''
}
},
props: {
mobile: {
type: String,
default: ''
},
templateCode: {
type: String,
default: ''
},
action: {
type: String,
default: '用户注册' //设置支付密码
}
},
methods: {
//获取验证码
async getCode(){
if(this.timeDown > 0){
return;
}
this.$util.throttle(()=>{
const mobile = this.mobile || this.$store.state.userInfo.username;;
if(!checkStr(mobile, 'mobile')){
this.$util.msg('手机号码格式不正确');
return;
}
this.loading = true;
this.$request('smsCode', 'send', {
mobile,
action: this.action, //uni短信必填
TemplateCode: this.templateCode, //阿里云必填
}).then(response=>{
this.$util.msg(response.msg);
this.loading = false;
if(response.status === 1){
this.countDown(60);
}
}).catch(err=>{
this.$util.msg('验证码发送失败');
this.loading = false;
console.log(err);
})
}, 2000)
},
//倒计时
countDown(timer){
timer --;
this.timeDown = timer;
if(timer > 0){
setTimeout(()=>{
this.countDown(timer);
}, 1000)
}
},
}
}
</script>
<style scoped lang="scss">
.mix-get-code{
flex-shrink: 0;
display: flex;
justify-content: space-between;
align-items: center;
height: 36rpx;
&:before{
content: '';
width: 0;
height: 40;
border-right: 1px solid #f0f0f0;
}
.loading{
margin-right: 8rpx;
}
.text{
line-height: 28rpx;
font-size: 26rpx;
color: #40a2ff;
&.disabled{
color: #ccc;
}
}
}
</style>