userDefault.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691
  1. <template>
  2. <div class="mainBox">
  3. <div class="layerBox">
  4. <el-form ref="form" :model="form" :rules="loginRules" class="login-form" autocomplete="on" label-position="left" label-width="120px">
  5. <div class="formDiv">
  6. <!--选择角色 start------------------------------------------>
  7. <el-form-item label="所属角色:" :label-width="formLabelWidth" prop="role_id" class="custom-align-right">
  8. <div class="formLabelFloatBox">
  9. <el-select v-model="form.role_id" placeholder="请选择..">
  10. <el-option
  11. v-for="item in role_idArr"
  12. :key="item.value"
  13. :label="item.label"
  14. :value="item.value">
  15. </el-option>
  16. </el-select>
  17. </div>
  18. </el-form-item>
  19. <!--选择角色 end------------------------------------------>
  20. <el-form-item label="登录账号:" :label-width="formLabelWidth" prop="user_name" class="custom-align-right">
  21. <el-input v-model="form.user_name" autocomplete="off" placeholder="请输入登录账号.."></el-input>
  22. </el-form-item>
  23. <div v-if="editId==''">
  24. <!--新密码 start------------------------------------------>
  25. <div class="PasswordBox">
  26. <el-form-item prop="password" label="登录密码:" class="custom-align-right">
  27. <div class="PasswordBody">
  28. <el-input
  29. :key="passwordType1"
  30. ref="password1"
  31. v-model="form.password"
  32. :type="passwordType1"
  33. placeholder="请输入密码"
  34. name="password"
  35. tabindex="2"
  36. autocomplete="off"
  37. @blur="capsTooltip2 = false"
  38. />
  39. <span class="show-pwd" @click="showPwd(1)">
  40. <svg-icon :icon-class="passwordType1 === 'password' ? 'eye' : 'eye-open'" />
  41. </span>
  42. </div>
  43. </el-form-item>
  44. </div>
  45. <!--新密码 end------------------------------------------>
  46. <!--新密码 start------------------------------------------>
  47. <div class="PasswordBox">
  48. <el-form-item prop="confirm_password" label="确认密码:" class="custom-align-right">
  49. <div class="PasswordBody">
  50. <el-input
  51. :key="passwordType2"
  52. ref="password2"
  53. v-model="form.confirm_password"
  54. :type="passwordType2"
  55. placeholder="请输入密码"
  56. name="password"
  57. tabindex="2"
  58. autocomplete="off"
  59. @blur="capsTooltip2 = false"
  60. />
  61. <span class="show-pwd" @click="showPwd(2)">
  62. <svg-icon :icon-class="passwordType2 === 'password' ? 'eye' : 'eye-open'" />
  63. </span>
  64. </div>
  65. </el-form-item>
  66. </div>
  67. <!--新密码 end------------------------------------------>
  68. </div>
  69. <el-form-item label="真实姓名:" :label-width="formLabelWidth" prop="real_name" class="custom-align-right">
  70. <el-input v-model="form.real_name" autocomplete="off" placeholder="请输入真实姓名.."></el-input>
  71. </el-form-item>
  72. <el-form-item label="照片:" :label-width="formLabelWidth" prop="photoUrl" :class="['custom-form-item']" class="custom-align-right">
  73. <div class="uploaderBox">
  74. <!--图片上传组件 start ------------------------------------------------------------>
  75. <div class="avatar-upload-container" @mouseenter="hovering = true" @mouseleave="hovering = false">
  76. <!-- 上传组件 -->
  77. <el-upload
  78. class="avatar-uploader"
  79. action="#"
  80. :show-file-list="false"
  81. :before-upload="beforeAvatarUpload"
  82. >
  83. <!-- 预览图片 -->
  84. <img v-if="photoUrl" :src="photoUrl" class="avatar">
  85. <!-- 上传图标 -->
  86. <div v-else class="chooseImgDiv">
  87. <div>
  88. <img src="@/assets/public/upload/noImage.png">
  89. <div>选择图片</div>
  90. </div>
  91. </div>
  92. </el-upload>
  93. <!-- 删除按钮,当鼠标悬浮时显示 -->
  94. <div v-if="hovering && photoUrl" class="delete-button" @click="handleDelete">
  95. <i class="el-icon-delete"></i>
  96. </div>
  97. </div>
  98. <!--图片上传组件 end ------------------------------------------------------------>
  99. </div>
  100. </el-form-item>
  101. <el-form-item label="身份证号:" :label-width="formLabelWidth" prop="id_card" class="custom-align-right">
  102. <el-input v-model="form.id_card" autocomplete="off" placeholder="请输入身份证号.."></el-input>
  103. </el-form-item>
  104. <el-form-item label="出生年月:" :label-width="formLabelWidth" prop="birthday" class="custom-align-right">
  105. <el-date-picker
  106. v-model="form.birthday"
  107. type="date"
  108. placeholder="选择日期"
  109. disabled
  110. >
  111. </el-date-picker>
  112. </el-form-item>
  113. <el-form-item label="性别:" :label-width="formLabelWidth" prop="gender" class="custom-align-right">
  114. <el-radio v-model="form.gender" label="1">男</el-radio>
  115. <el-radio v-model="form.gender" label="2">女</el-radio>
  116. </el-form-item>
  117. <el-form-item label="手机号:" :label-width="formLabelWidth" prop="mobile" class="custom-align-right">
  118. <el-input v-model="form.mobile" autocomplete="off" placeholder="请输入手机号.."></el-input>
  119. </el-form-item>
  120. <el-form-item label="有效期:" :label-width="formLabelWidth" prop="timeList" class="custom-align-right">
  121. <el-date-picker
  122. v-model="timeList"
  123. type="daterange"
  124. :disabled="form.long_time === 1"
  125. range-separator="至"
  126. start-placeholder="开始日期"
  127. end-placeholder="结束日期"
  128. :picker-options="pickerOptions">
  129. </el-date-picker>
  130. <el-checkbox v-model="form.long_time" :true-label="1" :false-label="0" class="longTimeCheckbox">无限期</el-checkbox>
  131. </el-form-item>
  132. <el-form-item label="籍贯:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  133. <CityCascader v-model="form.native_place_arr_id" @update-city-id="update_native_place_arr_id"></CityCascader>
  134. </el-form-item>
  135. <el-form-item label="QQ:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  136. <el-input v-model="form.qq" autocomplete="off" placeholder="请输入QQ号.."></el-input>
  137. </el-form-item>
  138. <el-form-item label="电子邮箱:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  139. <el-input v-model="form.email" autocomplete="off" placeholder="请输入电子邮箱.."></el-input>
  140. </el-form-item>
  141. <el-form-item label="邮编:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  142. <el-input v-model="form.zip_code" autocomplete="off" placeholder="请输入邮编.."></el-input>
  143. </el-form-item>
  144. <el-form-item label="详细地址:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  145. <CityCascader v-model="form.address_arr_id" @update-city-id="update_address_arr_id"></CityCascader>
  146. </el-form-item>
  147. <el-form-item label="" :label-width="formLabelWidth" prop="" class="custom-align-right">
  148. <el-input v-model="form.address" autocomplete="off" placeholder="请输入门牌号.."></el-input>
  149. </el-form-item>
  150. <el-form-item label="相关资料:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  151. <el-upload
  152. class="upload-demo"
  153. :action="uploadFileUrl"
  154. :headers="headers"
  155. :on-preview="handlePreview"
  156. :on-remove="handleRemove"
  157. :before-remove="beforeRemove"
  158. :on-success="handleUploadSuccess"
  159. multiple
  160. :limit="30"
  161. :on-exceed="handleExceed"
  162. :file-list="otherList">
  163. <el-button size="small" type="primary">点击上传</el-button>
  164. <div slot="tip" class="el-upload__tip">每张图片最大1MB,最多上传30张图片。</div>
  165. </el-upload>
  166. </el-form-item>
  167. <el-form-item label="提示词:" :label-width="formLabelWidth" prop="" class="custom-align-right">
  168. <el-input type="textarea" v-model="form.remark" class="custom-textarea" placeholder="请输入提示词"></el-input>
  169. </el-form-item>
  170. </div>
  171. </el-form>
  172. </div>
  173. <div class="bottomBtnBox">
  174. <el-button type="info" @click="goList">返回</el-button>
  175. <el-button type="primary" @click="addData" v-if="editId==''">提交</el-button>
  176. <el-button type="primary" @click="editData" v-if="editId!=''">修改</el-button>
  177. <el-button type="warning" @click="resetPassword" v-if="editId!=''">重置密码</el-button>
  178. </div>
  179. </div>
  180. </template>
  181. <script>
  182. // 引入公用样式
  183. import '@/styles/global.less';
  184. // 引入baseUrl
  185. import URL from '@/utils/baseUrl';
  186. //城市级联选择器
  187. import CityCascader from './CityCascader';
  188. //格式化时间
  189. import { formatLocalDate } from '@/utils/public';
  190. export default {
  191. components: {
  192. CityCascader, //城市级联选择器
  193. },
  194. data() {
  195. let self = this;
  196. // 配置验证规则:用于表单验证
  197. const validatePassword = (rule, value, callback) => {
  198. if (value.length < 6) {
  199. callback(new Error('密码不能低于6位!'))
  200. } else {
  201. callback()
  202. }
  203. }
  204. const validateEmpty = (rule,value,callback) => {
  205. if (!value || value.trim() === "") {
  206. callback(new Error('该项不能为空!'));
  207. } else {
  208. callback();
  209. }
  210. }
  211. const validateArray = (rule,value,callback) => {
  212. if (value.length == 0) {
  213. callback(new Error('该项不能为空!'))
  214. } else {
  215. callback()
  216. }
  217. }
  218. const validateTime = (rule,value,callback) => {
  219. if(value==="NaN-NaN-NaN NaN:NaN:NaN"){
  220. callback(new Error('该项不能为空!'))
  221. }else{
  222. callback()
  223. }
  224. }
  225. const validateTimeTo = (rule,value,callback) => {
  226. if(self.timeList.length == 0&&self.form.long_time==0){
  227. callback(new Error('该项不能为空!'))
  228. }else{
  229. callback()
  230. }
  231. }
  232. const validateIdcard = (rule,value,callback) => {
  233. const idCardRegex = /^(?:\d{15}|\d{18}|\d{17}[\dXx])$/; // 正则表达式验证身份证号
  234. if (!value || value.trim() === "") {
  235. callback(new Error('该项不能为空!'));
  236. } else if (!idCardRegex.test(value.trim())) {
  237. callback(new Error('请输入有效的身份证号')); // 更新错误信息
  238. } else {
  239. console.log("身份证号验证通过!");
  240. self.extractBirthdayFromIdcard();
  241. callback();
  242. }
  243. }
  244. return {
  245. formLabelWidth:"120px",
  246. editId:"",
  247. uploadFileUrl:URL.testUrl+"/public/uploadFile",//获得上传地址
  248. headers: {},
  249. form:{
  250. type_id:1,//个人会员
  251. role_id:"",//角色id
  252. user_name:"",//登录账号
  253. password:"",//密码
  254. confirm_password:"",//确认密码
  255. real_name:"",//真实姓名
  256. avatar:"",//照片
  257. id_card:"",//身份证号
  258. birthday:"",//出生年月
  259. gender:"1",//性别
  260. mobile:"",//手机号
  261. native_place_arr_id:"",//籍贯
  262. address_arr_id:"",//详细地址
  263. address:"",//详细地址
  264. from_time:"",//有效期开始时间
  265. to_time:"",//有效期结束时间
  266. long_time:0,//是否为长期 //长期1:长期 0:非长期
  267. qq:"",//QQ
  268. email:"",//电子邮箱
  269. other:[],//相关资料
  270. remark:"",//提示词
  271. },
  272. timeList:[],//时间段
  273. otherList:[],//相关资料列表
  274. role_idArr:[],//角色id池
  275. //上传照片
  276. photoUrl:'',
  277. hovering: false, // 鼠标悬浮状态 悬浮时显示删除
  278. //密码验证
  279. capsTooltip1: false,
  280. capsTooltip2: false,
  281. passwordType1: 'password',
  282. passwordType2: 'password',
  283. //配置from表单验证规则
  284. loginRules: {
  285. //1.角色id
  286. role_id: [{ required: true, trigger: 'blur', validator: validateArray }],
  287. //2.登录账号
  288. user_name: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  289. //3.密码和确认密码
  290. password: [{ required: true, trigger: 'blur', validator: validatePassword }],
  291. confirm_password: [{ required: true, trigger: 'blur', validator: validatePassword }],
  292. //5.真实姓名
  293. real_name: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  294. //6.手机号
  295. mobile: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  296. //7.身份证号
  297. id_card: [{ required: true, trigger: 'blur', validator: validateIdcard }],
  298. //8.性别
  299. gender: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  300. //9.手机号
  301. mobile: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  302. //10.照片
  303. photoUrl: [{ required: true, trigger: 'blur', validator: validateEmpty }],
  304. //11.出生年月
  305. birthday: [{ required: true, trigger: 'blur', validator: validateTime }],
  306. //12.有效期
  307. timeList:[{ required: true, trigger: 'blur', validator: validateTimeTo }]
  308. },
  309. //时间跨度
  310. pickerOptions: {
  311. selectableRange: '1900-01-01 to 2100-12-31', // 允许选择的日期范围
  312. disabledDate(time) {
  313. return time.getTime() < Date.now() - 86400000; // 禁用今天之前的日期
  314. },
  315. },
  316. };
  317. },
  318. methods: {
  319. //1.表单收集 start ------------------------------------------------------------>
  320. //1.1切换密码框的显示与隐藏
  321. showPwd(num) {
  322. const passwordTypeKey = 'passwordType' + num; //动态生成 passwordType 的键
  323. const passwordRefKey = 'password' + num; //动态生成 password 的引用
  324. // 切换密码类型
  325. if (this[passwordTypeKey] === 'password') {
  326. this[passwordTypeKey] = ''; //显示密码
  327. } else {
  328. this[passwordTypeKey] = 'password'; //隐藏密码
  329. }
  330. // 使用 $nextTick 聚焦到对应的密码输入框
  331. this.$nextTick(() => {
  332. this.$refs[passwordRefKey].focus(); //聚焦到对应的密码输入框
  333. });
  334. },
  335. //1.2获得角色列表池
  336. getRoleList(){
  337. let data = {
  338. page:1,
  339. pageSize:100
  340. }
  341. this.$store.dispatch('userRole/roleList',data).then(res=>{
  342. this.role_idArr = res.data.rows.map(item => ({
  343. value: item.id,
  344. label: item.role_name
  345. }));
  346. }).catch(error=>{
  347. this.$message({
  348. type: 'warning',
  349. message: '网络错误,请重试!'
  350. });
  351. })
  352. },
  353. //1.4更新籍贯
  354. update_native_place_arr_id(value){
  355. console.log("籍贯ID已更新:", value);
  356. this.form.native_place_arr_id = value;
  357. },
  358. //1.5更新详细地址
  359. update_address_arr_id(value){
  360. console.log("详细地址ID已更新:", value);
  361. this.form.address_arr_id = value;
  362. },
  363. //1.5重置表单
  364. clearData(){
  365. },
  366. //表单收集 end ------------------------------------------------------------>
  367. //2.提交表单 start ------------------------------------------------------------>
  368. //2.1 上传图片操作
  369. beforeAvatarUpload(file) {
  370. const isJPG = file.type === 'image/jpeg';
  371. const isPNG = file.type === 'image/png';
  372. const isLt2M = file.size / 1024 / 1024 < 2;
  373. if (!isJPG && !isPNG) {
  374. this.$message.error('上传头像图片只能是 JPG 或 PNG 格式!');
  375. return false;
  376. }
  377. if (!isLt2M) {
  378. this.$message.error('上传头像图片大小不能超过 2MB!');
  379. return false;
  380. }
  381. const formData = new FormData();
  382. formData.append('file', file);
  383. this.$store.dispatch('pool/uploadFile',formData).then(res=> {
  384. this.photoUrl = res.data.imgUrl;//显示缩略图
  385. this.form.avatar = res.data.imgUrl;//提供表单地址
  386. console.log(res.data.imgUrl)
  387. }).catch(() => {
  388. this.$message({
  389. type: 'warning',
  390. message: '网络错误,请重试!'
  391. });
  392. })
  393. // 阻止默认的上传行为
  394. return false;
  395. },
  396. //2.2 删除图片
  397. handleDelete() {
  398. this.photoUrl = ''; // 清空图片 URL
  399. },
  400. //2.3 多文件上传
  401. handleRemove(file, fileList) {
  402. console.log(file, fileList);
  403. },
  404. handlePreview(file) {
  405. console.log(file);
  406. },
  407. handleExceed(files, fileList) {
  408. this.$message.warning(`当前限制选择 30 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
  409. },
  410. beforeRemove(file, fileList) {
  411. return this.$confirm(`确定移除 ${ file.name }?`);
  412. },
  413. //获取token
  414. getTokenFromCookie() {
  415. const name = "Admin-Token=";
  416. const decodedCookie = decodeURIComponent(document.cookie);
  417. const cookieArray = decodedCookie.split(';');
  418. for (let i = 0; i < cookieArray.length; i++) {
  419. let cookie = cookieArray[i].trim();
  420. if (cookie.indexOf(name) === 0) {
  421. return cookie.substring(name.length, cookie.length); // 返回 token
  422. }
  423. }
  424. return ""; // 如果没有找到 token,返回空字符串
  425. },
  426. //设置token
  427. setHeaders() {
  428. this.token = this.getTokenFromCookie(); // 从 cookie 中获取 token
  429. this.headers = { token: this.token }; // 设置 headers
  430. console.log(this.headers); // 打印 headers
  431. },
  432. //上传成功以后
  433. handleUploadSuccess(response) {
  434. this.form.other.push(response.data.imgUrl)
  435. console.log('上传成功:', response);
  436. console.log(this.form.other);
  437. },
  438. //提交表单
  439. addData(){
  440. //1.格式化时间戳
  441. this.form.birthday = formatLocalDate(this.form.birthday);
  442. if(this.form.long_time==0){
  443. this.form.from_time = formatLocalDate(this.timeList[0]);
  444. this.form.to_time = formatLocalDate(this.timeList[1]);
  445. }else{
  446. this.form.from_time = "";
  447. this.form.to_time = "";
  448. delete this.form.from_time;
  449. delete this.form.to_time;
  450. }
  451. //2.开始验证
  452. this.$refs.form.validate(valid => {
  453. if (valid) {
  454. //3.验证用户是否已经存在
  455. this.$store.dispatch('userMember/verifyUserInfo',{user_name:this.form.user_name}).then(res=>{
  456. if(res.code==0){
  457. //如果code为0表示用户不存在,提交表单
  458. this.$store.dispatch('userMember/createUser',this.form).then(res=>{
  459. if(res.code==200){
  460. console.log(res);
  461. this.$message({
  462. type: 'success',
  463. message: '用户添加成功!'
  464. });
  465. this.goList();
  466. }else{
  467. this.$message({
  468. type: 'warning',
  469. message: res.message
  470. });
  471. }
  472. })
  473. }else if(res.code==200){
  474. //如果code==200 表示用户存在,阻止进一步提交
  475. this.$message({
  476. type: 'warning',
  477. message: '该账号已被注册,请更换其他账号!'
  478. });
  479. }
  480. }).catch(error=>{
  481. this.$message({
  482. type: 'warning',
  483. message: '网络错误,请重试!'
  484. });
  485. })
  486. }
  487. })
  488. },
  489. //提交表单 start ------------------------------------------------------------>
  490. //3.编辑表单 start ------------------------------------------------------------>
  491. //获得用户信息
  492. getUserInfo(){
  493. this.$store.dispatch('userMember/getUser',{id:this.editId}).then(res=>{
  494. console.log(res);
  495. //回显数据
  496. this.form.type_id = res.data.type_id;
  497. this.form.user_name = res.data.user_name;
  498. this.form.role_id = res.data.role_id;
  499. this.form.real_name = res.data.real_name;
  500. this.form.mobile = res.data.mobile;
  501. this.photoUrl = res.data.avatar;
  502. this.form.avatar = res.data.avatar;
  503. this.form.id_card = res.data.id_card;
  504. this.form.birthday = res.data.birthday;
  505. //还原有效期
  506. if(res.data.long_time==0){
  507. this.timeList = [
  508. res.data.from_time,
  509. res.data.to_time
  510. ]
  511. this.form.from_time = res.data.from_time;
  512. this.form.to_time = res.data.to_time;
  513. this.form.long_time = 0;
  514. }else{
  515. this.form.from_time = "";
  516. this.form.to_time = "";
  517. this.form.long_time = 1;
  518. }
  519. this.form.qq = res.data.qq;
  520. this.form.email = res.data.email;
  521. this.form.address = res.data.address;
  522. this.form.zip_code = res.data.zip_code;
  523. this.form.remark = res.data.remark;
  524. this.form.native_place_arr_id = res.data.native_place_arr_id;
  525. // 处理文件列表
  526. const fileArrayString = res.data.other; // 假设这是一个字符串格式的数组
  527. const fileArray = JSON.parse(fileArrayString); // 解析为数组
  528. this.form.other.push(...fileArray); // 将解析出来的值 push 到 this.form.other
  529. // 将文件列表赋值给 otherList,生成默认文件名
  530. this.otherList = fileArray.map((url, index) => ({
  531. name: `文件${index + 1}`, // 生成文件名
  532. url: url, // 文件的 URL
  533. status: 'success' // 设置状态为 success
  534. }));
  535. }).catch(error=>{
  536. this.$message({
  537. type: 'warning',
  538. message: '网络错误,请重试!'
  539. });
  540. })
  541. },
  542. //修改用户
  543. editData(){
  544. //1.格式化时间戳
  545. this.form.birthday = formatLocalDate(this.form.birthday);
  546. if(this.form.long_time==0){
  547. this.form.from_time = formatLocalDate(this.timeList[0]);
  548. this.form.to_time = formatLocalDate(this.timeList[1]);
  549. }else{
  550. this.form.from_time = "";
  551. this.form.to_time = "";
  552. }
  553. this.$refs.form.validate(valid => {
  554. if (valid) {
  555. //1.验证用户是否存在
  556. this.$store.dispatch('userMember/verifyUserInfo',{id:this.editId,user_name:this.form.user_name}).then(res=>{
  557. if(res.code==0){
  558. console.log(this.form);
  559. this.form.native_place_arr_id = JSON.parse(this.form.native_place_arr_id);
  560. //2.设置修改的用户id
  561. this.form.id = this.editId;
  562. //3.提交用户修改
  563. //如果code为0表示用户不存在,提交表单
  564. this.$store.dispatch('userMember/updateUser',this.form).then(res=>{
  565. console.log(res);
  566. this.$message({
  567. type: 'success',
  568. message: '用户添加成功!'
  569. });
  570. this.goList();
  571. })
  572. }else if(res.code==200){
  573. //如果code==200 表示用户存在,阻止进一步提交
  574. this.$message({
  575. type: 'warning',
  576. message: '该账号已被注册,请更换其他账号!'
  577. });
  578. }
  579. }).catch(error=>{
  580. this.$message({
  581. type: 'warning',
  582. message: '网络错误,请重试!'
  583. });
  584. })
  585. }
  586. })
  587. },
  588. //重置密码
  589. resetPassword(){
  590. let password = Math.random().toString(36).slice(-6); // 随机生成6个字母的组合
  591. this.$store.dispatch('userMember/resetPassword',{id:this.editId,password:password}).then(res=> {
  592. if(res.code==200){
  593. this.$message({
  594. type: 'success',
  595. message: '密码重置为:' + password
  596. });
  597. }
  598. }).catch(() => {
  599. this.$message({
  600. type: 'warning',
  601. message: '网络错误,请重试!'
  602. });
  603. })
  604. },
  605. //编辑表单 end ------------------------------------------------------------>
  606. goList(){
  607. this.$router.push({
  608. path: '/userList',
  609. });
  610. },
  611. //提取身份证号中的出生日期
  612. extractBirthdayFromIdcard(){
  613. let idCard = this.form.id_card;
  614. // 1. 取出身份证中的生日部分,例如 "20250129"
  615. let birthStr = idCard.substring(6, 14);
  616. // 2. 截取年、月、日
  617. let year = birthStr.substring(0, 4); // 2025
  618. let month = birthStr.substring(4, 6); // 01
  619. let day = birthStr.substring(6, 8); // 29
  620. // 3. 拼接成需要的格式 "YYYY-MM-DD 00:00:00"
  621. let birthDateTime = `${year}-${month}-${day} 00:00:00`;
  622. this.form.birthday = birthDateTime;
  623. },
  624. },
  625. mounted(){
  626. this.getRoleList();
  627. //判断是新建还是回显
  628. if(this.$route.query.id!=undefined){
  629. this.editId = this.$route.query.id;
  630. console.log("编辑用户!")
  631. this.getUserInfo();
  632. }else{
  633. console.log("添加用户!")
  634. }
  635. //设置token
  636. this.setHeaders(); // 在组件挂载时设置 headers
  637. }
  638. };
  639. </script>
  640. <style scoped lang="less">
  641. .PasswordBox {
  642. display: flex;
  643. align-items: center;
  644. .el-form-item {
  645. flex: 1;
  646. }
  647. .PasswordTitle {
  648. width:120px;
  649. text-align: right;
  650. margin-right: 10px;
  651. margin-bottom:22px;
  652. }
  653. .PasswordBody {
  654. flex: 1;
  655. display: flex;
  656. align-items: center;
  657. }
  658. .show-pwd {
  659. margin-left: 10px;
  660. }
  661. }
  662. .longTimeCheckbox {
  663. margin-left: 10px;
  664. }
  665. //执行v-deep穿透scope选择器 start------------------------------------------------------------>*/
  666. ::v-deep .custom-form-item > .el-form-item__label {
  667. line-height: 140px !important;
  668. }
  669. ::v-deep .custom-textarea .el-textarea__inner {
  670. resize: none; /* 禁止用户拖拽调整大小 */
  671. }
  672. ::v-deep .custom-align-right .el-form-item__label {
  673. text-align: right; /* 设置标签文字右对齐 */
  674. }
  675. ::v-deep .el-select {
  676. width: 100%; /* 禁止用户拖拽调整大小 */
  677. }
  678. //执行v-deep穿透scope选择器 end------------------------------------------------------------>*/
  679. </style>