1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
| <template>
| <view class="pwd-retrieve-container">
| <uni-forms ref="form" :value="user" labelWidth="80px">
| <uni-forms-item name="oldPassword" label="旧密码">
| <uni-easyinput type="password" v-model="user.oldPassword" placeholder="请输入旧密码" />
| </uni-forms-item>
| <uni-forms-item name="newPassword" label="新密码">
| <uni-easyinput type="password" v-model="user.newPassword" placeholder="请输入新密码" />
| </uni-forms-item>
| <uni-forms-item name="confirmPassword" label="确认密码">
| <uni-easyinput type="password" v-model="user.confirmPassword" placeholder="请确认新密码" />
| </uni-forms-item>
| <button type="primary" @click="submit">提交</button>
| </uni-forms>
| </view>
| </template>
|
| <script>
| import { updateUserPwd } from "@/api/system/user"
|
| export default {
| data() {
| return {
| user: {
| oldPassword: undefined,
| newPassword: undefined,
| confirmPassword: undefined
| },
| rules: {
| oldPassword: {
| rules: [{
| required: true,
| errorMessage: '旧密码不能为空'
| }]
| },
| newPassword: {
| rules: [{
| required: true,
| errorMessage: '新密码不能为空',
| },
| {
| minLength: 6,
| maxLength: 20,
| errorMessage: '长度在 6 到 20 个字符'
| }
| ]
| },
| confirmPassword: {
| rules: [{
| required: true,
| errorMessage: '确认密码不能为空'
| }, {
| validateFunction: (rule, value, data) => data.newPassword === value,
| errorMessage: '两次输入的密码不一致'
| }
| ]
| }
| }
| }
| },
| onReady() {
| this.$refs.form.setRules(this.rules)
| },
| methods: {
| submit() {
| this.$refs.form.validate().then(res => {
| updateUserPwd(this.user.oldPassword, this.user.newPassword).then(response => {
| uni.showToast({
| title: '修改成功',
| mask: false,
| duration: 1000
| });
| uni.navigateBack();
| })
|
| })
| }
| }
| }
| </script>
|
| <style lang="scss">
| page {
| background-color: #ffffff;
| }
|
| .pwd-retrieve-container {
| padding-top: 36rpx;
| padding: 15px;
| }
| </style>
|
|