RegisterBar.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. })
  50. },
  51. handlePostCode() {
  52. if(this.sending) return
  53. const params = {
  54. action: '0', // 注册用户
  55. receiver: this.form.username
  56. }
  57. if(this.regPhone.test(this.form.username)) params.type = '1'
  58. if(this.regEmail.test(this.form.username)) params.type = '0'
  59. this.$axios.get('auth/getVerifyCode', {params}).then((res)=> {
  60. if(res.code === 200) {
  61. this.sending = true
  62. let interval = setInterval(() => {
  63. this.clock--
  64. if(this.clock === 0) {
  65. clearInterval(interval)
  66. interval = null
  67. this.clock = 60
  68. this.sending = false
  69. }
  70. }, 1000);
  71. }
  72. })
  73. },
  74. handlerLogin() {
  75. this.$axios.post('login',qs.stringify(this.form)).then((res)=> {
  76. this.$store.dispatch('login',res.result).then((token)=> {
  77. this.$axios.setToken(token, 'Bearer')
  78. this.handlerClose()
  79. this.getUserInfo()
  80. })
  81. })
  82. },
  83. getUserInfo() {
  84. this.$axios.get('members/getMemberInfo').then((res)=> {
  85. if(res.code === 200) {
  86. this.$store.commit('setUser',res.result.memberInfo)
  87. this.$emit('loginSucess')
  88. }
  89. })
  90. },
  91. handlerUsernameBlur(e) {
  92. this.showVcode = this.regPhone.test(e.target.value)
  93. },
  94. // 弹窗关闭,初始化注册面板
  95. resetInterfaceStatus() {
  96. this.errMsg = '';
  97. this.form.username = ''
  98. this.form.password = ''
  99. this.form.passwordConfirm = ''
  100. this.form.verifyCode = ''
  101. this.showVcode = false
  102. },
  103. handlerChangeLogin() {
  104. this.$emit('login','login')
  105. },
  106. handlerClose() {
  107. this.$emit('close')
  108. }
  109. }
  110. }
  111. </script>
  112. <template>
  113. <div class="user-login">
  114. <div class="logo">
  115. <h4 id="loginModalLabel" class="logo_PDF"></h4>
  116. </div>
  117. <div class="login_content">
  118. <input id="signup_account" v-model="form.username" class="login_input_user" type="text" placeholder="手机号/邮箱" @blur="handlerUsernameBlur">
  119. <br />
  120. <input id="signup_pwd1" v-model="form.password" class="login_input_password" type="password" placeholder="密码(6-16个字符,区分大小写)">
  121. <br />
  122. <input id="signup_pwd2" v-model="form.passwordConfirm" class="login_input_password" type="password" placeholder="确认密码">
  123. <br />
  124. <div v-show="showVcode" class="vcode_content">
  125. <input v-model="form.verifyCode" class="input_vcode_signup" placeholder="验证码">
  126. <span class="sent-vcode sent-vcode-signup" :class="{'sent-vcode-disabled': sending}" @click="handlePostCode"><a>{{sending ? clock+'秒' : '发送验证码'}}</a></span>
  127. </div>
  128. <div v-show="errMsg !== ''" class="error-mess error-mess-signup">
  129. <span id="error-message error-tip">{{errMsg}}</span>
  130. </div>
  131. <button id="btn-signup" type="submit" class="logging" :class="{'btn-signin': loginBtnDisabled}" :disabled="loginBtnDisabled" @click="vailidate">注册</button>
  132. <div class="login-now">
  133. <div class="term">
  134. <span>轻触上面的“注册”按钮,即表示你同意我们的<a target="_blank" href="/terms">条款</a></span>
  135. </div>
  136. <div class="switch_login">
  137. <span>已经有账号?<a class="cursor-pointer" @click="handlerChangeLogin">登录</a></span>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. </template>