web-retail-h5/pages/forgetPassword/index.vue

255 lines
6.9 KiB
Vue
Raw Normal View History

2025-03-23 09:29:40 +08:00
<!--
* @Descripttion:
* @version:
* @Author: 王三华
* @Date: 2023-05-18 14:42:53
-->
<template>
<view class="main">
<view class="contents">
<u-form ref="uForm"
:model="emailObj"
class="paddings"
labelWidth="auto">
<u-form-item :label="$t('MN_T_1')"
label-width="80px"
prop="memberCode">
<u-input v-model="emailObj.memberCode"
class="border-color"
:placeholder="$t('MN_T_1')"
placeholder-class="place-class" />
</u-form-item>
<u-form-item label="用户密码"
label-width="80px"
prop="newPassword">
<u-input v-model="emailObj.newPassword"
class="border-color"
:placeholder="$t('w_0046')"
type="password"
placeholder-class="place-class" />
</u-form-item>
<u-form-item :label="$t('MN_F_30')"
label-width="80px"
prop="loginPassword">
<u-input v-model="emailObj.loginPassword"
class="border-color"
type="password"
:placeholder="$t('w_0332')"
placeholder-class="place-class" />
</u-form-item>
<u-form-item :label="$t('w_0052')"
label-width="80px"
prop="phone"
style="display: flex;">
<u-input v-model="emailObj.phone"
class="border-color"
:placeholder="$t('w_0053')"
maxlength="20"
type="number"
placeholder-class="place-class" />
</u-form-item>
<u-form-item :label="$t('w_0043')"
label-width="80px"
prop="code">
<u-input v-model="emailObj.code"
class="border-color width-s"
:placeholder="$t('w_0057')"
placeholder-class="place-class" />
<button :disabled="disabled"
class="yzm"
@click.stop="getCode()">
{{getCodeText}}
</button>
</u-form-item>
</u-form>
</view>
<u-button class="btn"
shape="circle"
type="success"
@click="submit">{{$t('w_0035')}}</u-button>
<view style="height: 20rpx;"></view>
</view>
</template>
<script>
import * as api from '@/config/login.js'
import { setToken } from '@/config/auth.js'
import address from '@/components/address.vue'
import store from '@/store'
import { forgetPassword } from '../../config/login'
export default {
data() {
let validatePwd = (rule, value, callback) => {
if (this.emailObj.newPassword != value) {
callback(new Error('与新密码不一致,请重新输入'))
} else {
callback()
}
}
return {
getCodeText: this.$t('w_0055'),
disabled: false,
time: 60,
yzmCheck: false,
userInfo: '',
emailObj: {
memberCode: '',
newPassword: '',
loginPassword: '',
phone: '',
code: '',
},
rules: {
memberCode: [
{ required: true, trigger: 'blur', message: this.$t('w_0046') },
],
code: [
{ required: false, trigger: 'blur', message: this.$t('w_0057') },
],
newPassword: [
{ required: true, trigger: 'blur', message: '请输入密码' },
],
loginPassword: [{ validator: validatePwd, trigger: 'blur' }],
phone: [
{ required: false, trigger: 'blur', message: this.$t('w_0053') },
],
},
}
},
onLoad(option) {
this.userInfo = uni.getStorageSync('User')
},
onReady() {
this.$refs.uForm.setRules(this.rules)
},
methods: {
submit() {
this.$refs.uForm.validate().then((res) => {
api.forgetPassword(this.emailObj).then((res) => {
if (res.code == '200') {
uni.showToast({
title: res.msg,
icon: 'none',
success() {
setTimeout(() => {
uni.navigateTo({
url: '/pages/login/index',
})
}, 2000)
},
})
} else {
uni.showToast({
icon: 'none',
title: res.msg,
})
}
})
})
},
getCode() {
// this.disabled = true
// this.getCodeText = "发送中..." //发送验证码
// this.getCodeisWaiting = true;
// this.getCodeBtnColor = "rgba(255,255,255,0.5)" //追加样式,修改颜色
this.getYzm()
},
getYzm() {
this.$refs.uForm.validate().then((res) => {
api.forgetVerification(this.emailObj).then((res) => {
if (res.code == '200') {
setTimeout(() => {
//this.$common.msg(this.$t('MY_WAL_49'))
uni.showToast({
title: this.$t('MY_WAL_49'),
icon: 'none',
}) //弹出提示框
this.setTimer() //调用定时器方法
}, 1000)
}
})
})
},
setTimer() {
this.disabled = true
let holdTime = 60 //定义变量并赋值
this.getCodeText = this.$t('w_0347') + '(60)'
//setInterval是一个实现定时调用的函数可按照指定的周期以毫秒计来调用函数或计算表达式。
//setInterval方法会不停地调用函数直到 clearInterval被调用或窗口被关闭。
this.time = setInterval(() => {
if (holdTime <= 0) {
this.disabled = false
this.getCodeisWaiting = false
this.getCodeBtnColor = '#ffffff'
this.getCodeText = this.$t('w_0055')
clearInterval(this.time) //清除该函数
return //返回前面
}
this.getCodeText = this.$t('w_0347') + '(' + holdTime + ')'
holdTime--
}, 1000)
},
},
}
</script>
<style lang="scss" scoped>
/deep/ uni-button:after {
border: none;
}
/deep/ .u-form-item__body__right__message {
margin-left: 170rpx !important;
}
.yzm {
// width: 161rpx;
height: 74rpx;
line-height: 74rpx;
text-align: center;
color: #fff;
background: #2fbc42;
border-radius: 40rpx;
margin-left: 30rpx;
font-size: 24rpx;
}
/deep/ .u-form-item:nth-child(2) {
width: 670rpx;
}
.contents {
background-color: #fff;
}
page {
background-color: #f2f2f2;
}
/deep/ .width-s {
width: 200rpx !important;
}
.paddings {
padding: 30rpx 0rpx;
margin: 0 40rpx;
}
.border-color {
border-radius: 50rpx;
padding-left: 50rpx !important;
font-size: 28rpx;
width: 400rpx;
height: 60rpx;
background: #f5f6f8;
border: none;
}
.btn {
background-color: #fb3024;
border: none;
height: 92rpx;
line-height: 92rpx;
font-size: 30rpx;
margin: 40rpx auto;
width: 690rpx;
}
</style>