register.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. <style lang="less">
  2. @import "./register.less";
  3. </style>
  4. <template>
  5. <div class="main">
  6. <navbar :user="user"></navbar>
  7. <div class="main-reg">
  8. <form ref="regForm" style="margin: 50px auto;">
  9. <!-- active0 -->
  10. <ul class="fhlist" style="width: 600px;margin:0 auto">
  11. <li class="mt10">
  12. <span class="title">
  13. <em class="fvx">*</em>手机号</span>
  14. <input type="text" name="phone" v-model="phone" class="ui-ipt iptform" :disabled="!!count" placeholder="输入手机">
  15. <span class="formver ng-scope" v-if="phone && phone.length!=11">
  16. <span class="p-ico ico-formver"></span>
  17. <span class="p-ico ico-worm"></span>请输入合法手机
  18. </span>
  19. </li>
  20. <li class="mt10">
  21. <span class="title"><em class="fvx">*</em>校验码</span>
  22. <input type="text" name="code" v-model="code" class="ui-ipt iptform2" placeholder="输入校验码">
  23. <el-button class="auth-code" type="primary" v-if="phone.length!=11" disabled>校验码</el-button>
  24. <el-button class="auth-code" type="primary" v-else-if="!count" @click="getCode()">校验码</el-button>
  25. <el-button class="auth-code" type="primary" disabled v-else>{{count}} s</el-button>
  26. <span class="formver ng-scope" style="font-size: 13px;" v-if="err.indexOf('校验码')>-1">
  27. <span class="p-ico ico-formver"></span>
  28. <span class="p-ico ico-worm"></span>{{err}}
  29. </span>
  30. <!-- <span class="formver ng-scope" v-if="phone.length==11 && code.length<4">
  31. <span class="p-ico ico-formver"></span>
  32. <span class="p-ico ico-worm"></span>请输入校验码
  33. </span> -->
  34. </li>
  35. <li class="mt10">
  36. <span class="title"><em class="fvx">*</em>姓名</span>
  37. <input type="text" name="name" v-model="name" class="ui-ipt iptform" placeholder="输入真实姓名" clearable>
  38. </li>
  39. <li class="mt10">
  40. <span class="title"><em class="fvx">*</em>身份证</span>
  41. <input type="text" name="cardId" v-model="cardId" class="ui-ipt iptform" placeholder="输入证件号" clearable>
  42. <span class="formver ng-scope" v-if="!is_ok_card(cardId)">
  43. <span class="p-ico ico-formver"></span>
  44. <span class="p-ico ico-worm"></span>请输入合法的份证号
  45. </span>
  46. </li>
  47. <li class="mt10">
  48. <span class="title"><em class="fvx">*</em>学历</span>
  49. <el-select placeholder="选择学历" v-model="education" class=" iptform" >
  50. <el-option v-for="(item,index) in educationList" :value="item" :label="item" v-bind:key="index" />
  51. </el-select>
  52. </li>
  53. <li class="mt10">
  54. <span class="title"><em class="fvx">*</em>工作单位</span>
  55. <input type="text" name="company" v-model="company" class="ui-ipt iptform" placeholder="输入工作单位" clearable>
  56. </li>
  57. <!-- <li class="mt10">
  58. <span class="title"><em class="fvx">*</em>证书编号</span>
  59. <input type="text" name="rzCode" v-model="rzCode" class="ui-ipt iptform" placeholder="输入证书编号" clearable>
  60. </li> -->
  61. <li class="mb5">
  62. <span class="title">
  63. <em class="fvx">*</em>账户密码</span>
  64. <input type="password" v-model="password" autocomplete="new-password" class="ui-ipt iptform ng-pristine ng-valid-pattern ng-invalid ng-invalid-required"
  65. placeholder="请填写登录密码" required="required">
  66. <span class="formver ng-scope" style="width:300px;font-size: 13px;" v-if="password&&password.length<6">
  67. <span class="p-ico ico-formver"></span>
  68. <span class="p-ico ico-worm"></span>请输入6~18位由字母、数字组合的登录密码!
  69. </span>
  70. </li>
  71. <li class="mb5">
  72. <span class="title">&nbsp;</span>
  73. <span class="code-case" style="float: left; margin-left: 120px;">
  74. <em :class="{'c1':passwordLevel==='sick' && password,'c2':passwordLevel==='middle','c3':passwordLevel==='strong'}">低</em>
  75. <em :class="{'c2':passwordLevel==='middle','c3':passwordLevel==='strong'}">中</em>
  76. <em class="last" :class="{'c3':passwordLevel==='strong'}">高</em>
  77. </span>
  78. </li>
  79. <li class="mb5">
  80. <span class="title"><em class="fvx">*</em>确认密码</span>
  81. <input type="password" name="confirmPassword" validate-password="" v-model="confirmPassword" ng-required="true"
  82. class="ui-ipt iptform ng-isolate-scope ng-pristine ng-invalid ng-invalid-required" placeholder="请填写登录密码"
  83. required="required">
  84. <span class="formver ng-scope" v-if="confirmPassword && confirmPassword!= password">
  85. <span class="p-ico ico-formver"></span>
  86. <span class="p-ico ico-worm"></span>前后密码不一致!
  87. </span>
  88. </li>
  89. <li class="mb5">
  90. <span class="title">&nbsp;</span>
  91. <span style="font-size: 10px;color: red; text-align: center;">{{err}}</span>
  92. </li>
  93. <li class="m-t-20">
  94. <span class="title">&nbsp;</span>
  95. <input class="ui-btn btn-r" type="button" value="提 交" :disabled="!cansubmit()" @click="submitData()">
  96. </li>
  97. </ul>
  98. </form>
  99. </div>
  100. </div>
  101. </template>
  102. <script>
  103. import data from "@/components/data/data.js";
  104. import {
  105. httpServer
  106. } from "@/components/httpServer/httpServer.js";
  107. import navbar from "@/components/nav/navbar.vue";
  108. import md5 from 'js-md5'
  109. export default {
  110. components: {
  111. navbar
  112. },
  113. data() {
  114. return {
  115. user: {
  116. nickname: ''
  117. },
  118. count: 0,
  119. name: '',
  120. passwordLevel: 'sick',
  121. password: '',
  122. educationList: window.baseConfig.educationList,
  123. confirmPassword: '',
  124. phone: '',
  125. code: "",
  126. err: '',
  127. cardId: '',
  128. timer: false,
  129. rules: data.rulesData(this.validatePass)
  130. };
  131. },
  132. watch: {
  133. password(val) {
  134. if (val.length < 6) {
  135. this.passwordLevel = 'sick';
  136. return
  137. }
  138. let pattern = [/[^0-9a-zA-Z]/, /[0-9a-z]/, /[A-Z]/];
  139. let patnum = 0
  140. for (let i = 0; i < pattern.length; i++) {
  141. if (pattern[i].test(val)) patnum++
  142. }
  143. if (patnum == 3) {
  144. this.passwordLevel = 'strong';
  145. } else if (patnum == 2) {
  146. this.passwordLevel = 'middle';
  147. } else {
  148. this.passwordLevel = 'sick';
  149. }
  150. }
  151. },
  152. methods: {
  153. submitData() {
  154. let that = this
  155. let param = {
  156. name: this.name,
  157. phone: this.phone,
  158. code: this.code,
  159. company: this.company,
  160. education: this.education,
  161. cardId: this.cardId,
  162. password: md5(this.password)
  163. }
  164. httpServer("Auth.register", param).then(res => {
  165. if (res.code == 200) {
  166. this.$msgbox({
  167. title: "注册成功",
  168. message: "恭喜你-注册成功",
  169. showCancelButton: false,
  170. confirmButtonText: "回到登入页面",
  171. beforeClose: (action, instance, done) => {
  172. that.$router.push('/');
  173. done();
  174. }
  175. })
  176. } else {
  177. this.err = res.msg;
  178. }
  179. })
  180. },
  181. checkPhone() {
  182. let phone = this.phone;
  183. if (!/^1[3456789]\d{9}$/.test(phone)) {
  184. this.$message.error("请填写正确的手机号");
  185. return false;
  186. }
  187. return true
  188. },
  189. validatePass(rule, value, callback) {
  190. if (value == this.password) {
  191. callback();
  192. } else {
  193. callback(new Error("两次密码不服"));
  194. }
  195. },
  196. getCode() {
  197. if (!this.checkPhone()) return;
  198. let phone = this.phone
  199. let type ="register"
  200. httpServer("Auth.getCode", {phone,type}).then(res => {
  201. if (res.code == 200) {
  202. this.$message.successMsg("发送成功", 1)
  203. this.startTimer()
  204. }
  205. })
  206. },
  207. startTimer() {
  208. const TIME_COUNT = 60; //更改倒计时时间
  209. if (this.timer) clearInterval(this.timer);
  210. this.count = TIME_COUNT;
  211. this.timer = setInterval(() => {
  212. if (this.count > 0) {
  213. this.count--;
  214. } else {
  215. clearInterval(this.timer); // 清除定时器
  216. this.timer = null;
  217. this.count = 0;
  218. }
  219. }, 1000)
  220. },
  221. is_ok_card( cardId ){
  222. if( !cardId ) return false;
  223. if( cardId.indexOf('H')>-1 || cardId.indexOf('W') >-1){
  224. return cardId.length==9 || cardId.length ==11;
  225. }
  226. return cardId.length ==18;
  227. },
  228. cansubmit() {
  229. if (this.isPhoneErr()) return false;
  230. if (!this.is_ok_card(this.cardId)) return false;
  231. if (!this.name) return false;
  232. if (!this.password || this.password != this.confirmPassword) return false;
  233. if (this.password.length < 6) return false;
  234. if (this.code.length < 4) return false;
  235. return true;
  236. },
  237. isPhoneErr() {
  238. return !/^[\d]{11}$/.test(this.phone);
  239. }
  240. }
  241. }
  242. </script>