RegisterBar.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <script>
  2. import qs from 'qs'
  3. export default {
  4. data() {
  5. const regPhone = /^1[3456789]\d{9}$/
  6. const regEmail = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/
  7. return {
  8. form: {
  9. username: '',
  10. password: '',
  11. passwordConfirm:'',
  12. verifyCode: '',
  13. // phone_zone: '86'
  14. },
  15. errMsg: '',
  16. sending: false,
  17. clock: 60,
  18. showVcode: false,
  19. regEmail,
  20. regPhone,
  21. }
  22. },
  23. computed: {
  24. loginBtnDisabled() {
  25. return !(this.form.username && this.form.password && this.form.passwordConfirm)
  26. }
  27. },
  28. methods: {
  29. // 点击注册前置校验
  30. vailidate() {
  31. if(!this.regPhone.test(this.form.username) && !this.regEmail.test(this.form.username)) {
  32. this.errMsg = '手机号/邮箱格式不对'
  33. }else if(this.form.password !== this.form.passwordConfirm) {
  34. this.errMsg = '两次输入的密码不一致'
  35. }else if(this.form.password.length < 6) {
  36. this.errMsg = '密码位数不能少于6位'
  37. }else if(this.form.password.length> 16){
  38. this.errMsg = '密码位数不能大于16位'
  39. }else {
  40. this.errMsg = ''
  41. this.handlerRegisterUser()
  42. }
  43. },
  44. handlerRegisterUser() {
  45. this.$axios.post('members/register',this.form).then((res)=> {
  46. if(res.code === 200) {
  47. this.handlerLogin(this.form)
  48. }
  49. if(res.data && res?.data?.code !== 200){
  50. this.errMsg = res.data.msg
  51. }
  52. })
  53. },
  54. handlePostCode() {
  55. if(this.sending) return
  56. const params = {
  57. action: '0', // 注册用户
  58. receiver: this.form.username
  59. }
  60. if(this.regPhone.test(this.form.username)) params.type = '1'
  61. if(this.regEmail.test(this.form.username)) params.type = '0'
  62. this.$axios.get('auth/getVerifyCode', {params}).then((res)=> {
  63. if(res.code === 200) {
  64. this.sending = true
  65. let interval = setInterval(() => {
  66. this.clock--
  67. if(this.clock === 0) {
  68. clearInterval(interval)
  69. interval = null
  70. this.clock = 60
  71. this.sending = false
  72. }
  73. }, 1000);
  74. }
  75. })
  76. },
  77. handlerLogin() {
  78. this.$axios.post('login',qs.stringify(this.form)).then((res)=> {
  79. this.$store.dispatch('login',res.result).then((token)=> {
  80. this.$axios.setToken(token, 'Bearer')
  81. this.handlerClose()
  82. this.getUserInfo()
  83. })
  84. })
  85. },
  86. getUserInfo() {
  87. this.$axios.get('members/getMemberInfo').then((res)=> {
  88. if(res.code === 200) {
  89. this.$store.commit('setUser',res.result.memberInfo)
  90. this.$emit('loginSucess')
  91. }
  92. })
  93. },
  94. handlerUsernameBlur(e) {
  95. this.showVcode = this.regPhone.test(e.target.value)
  96. },
  97. // 弹窗关闭,初始化注册面板
  98. resetInterfaceStatus() {
  99. this.errMsg = '';
  100. this.form.username = ''
  101. this.form.password = ''
  102. this.form.passwordConfirm = ''
  103. this.form.verifyCode = ''
  104. this.showVcode = false
  105. },
  106. handlerChangeLogin() {
  107. this.$emit('login','login')
  108. },
  109. handlerClose() {
  110. this.$emit('close')
  111. },
  112. changeErr(){
  113. this.errMsg = ''
  114. },
  115. keydown(event){
  116. if(event.keyCode == 32){
  117. event.returnValue = false
  118. this.errMsg = '请勿输入空格'
  119. }
  120. },
  121. }
  122. }
  123. </script>
  124. <template>
  125. <div class="user-login">
  126. <div class="logo">
  127. <h4 id="loginModalLabel" class="logo_PDF"></h4>
  128. </div>
  129. <div class="login_content relative">
  130. <div class="login_input_user_span w-20px h-20px absolute top-30px left-34px"></div>
  131. <input id="signup_account" v-model="form.username" class="login_input_user" type="text" placeholder="手机号/邮箱" @blur="handlerUsernameBlur" @input="changeErr">
  132. <br />
  133. <div class="login_input_password_span w-20px h-20px absolute top-90px left-34px"></div>
  134. <input id="signup_pwd1" v-model="form.password" class="login_input_password" type="password" placeholder="密码(6-16个字符,区分大小写)"
  135. @input="changeErr"
  136. @keydown="keydown($event)"
  137. oncut="return false" onpaste="return false" oncopy="return false">
  138. <br />
  139. <div class="login_input_password_span w-20px h-20px absolute top-150px left-34px"></div>
  140. <input id="signup_pwd2" v-model="form.passwordConfirm" class="login_input_password" type="password" placeholder="确认密码"
  141. @input="changeErr"
  142. @keydown="keydown($event)"
  143. oncut="return false" onpaste="return false" oncopy="return false">
  144. <br />
  145. <div v-show="showVcode" class="vcode_content">
  146. <input v-model="form.verifyCode" class="input_vcode_signup" placeholder="验证码">
  147. <span class="sent-vcode sent-vcode-signup" :class="{'sent-vcode-disabled': sending}" @click="handlePostCode"><a>{{sending ? clock+'秒' : '发送验证码'}}</a></span>
  148. </div>
  149. <div v-show="errMsg !== ''" class="error-mess error-mess-signup mb-5px">
  150. <span id="error-message error-tip">{{errMsg}}</span>
  151. </div>
  152. <button id="btn-signup" type="submit" class="logging" :class="{'btn-signin': loginBtnDisabled}" :disabled="loginBtnDisabled" @click="vailidate">注册</button>
  153. <div class="login-now">
  154. <div class="term">
  155. <span>轻触上面的“注册”按钮,即表示你同意我们的<a target="_blank" href="/terms">条款</a></span>
  156. </div>
  157. <div class="switch_login">
  158. <span>已经有账号?<a class="cursor-pointer" @click="handlerChangeLogin">登录</a></span>
  159. </div>
  160. </div>
  161. </div>
  162. </div>
  163. </template>