baseInfo.vue 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <template>
  2. <div class="base-info">
  3. <p class="title">基本信息</p>
  4. <el-form :model="ruleForm"
  5. :rules="rules"
  6. ref="ruleForm"
  7. label-width="104px"
  8. label-position="left"
  9. class="demo-ruleForm"
  10. :show-message="false">
  11. <el-form-item label="姓名:" prop="name" v-focus>
  12. <el-input v-model="ruleForm.name" size="small" :placeholder="ruleForm.name" :disabled="status" ref="nameEdit"></el-input>
  13. <div class="handle">
  14. <span v-if="status" @click="status = false">编辑</span>
  15. <span v-else @click="save()">保存</span>
  16. </div>
  17. </el-form-item>
  18. <el-form-item label="手机号:" prop="phonenumber">
  19. <el-input v-model="ruleForm.phonenumber" size="small" :placeholder="ruleForm.phonenumber" :disabled="true"></el-input>
  20. <slot :data="userInfo" name="phoneEdit"></slot>
  21. </el-form-item>
  22. <el-form-item label="密码:" prop="pass">
  23. <el-input v-model="ruleForm.pass" size="small" placeholder="******" :disabled="true"></el-input>
  24. <slot :data="userInfo" name="passEdit"></slot>
  25. </el-form-item>
  26. </el-form>
  27. </div>
  28. </template>
  29. <script>
  30. export default {
  31. name: 'baseInfo',
  32. data() {
  33. return {
  34. edit: {
  35. "classname": "common.usercenter.usercenter",
  36. "method": "updateUserMsg",
  37. "content": {
  38. "name":'',
  39. "phonenumber":'',
  40. }
  41. },
  42. ruleForm: {
  43. name:'',
  44. phonenumber:'',
  45. pass:'******'
  46. },
  47. rules: {
  48. name:[
  49. { required: true, message: '请输入姓名', trigger: 'blur' }
  50. ],
  51. phonenumber:[
  52. { required: true, message: '请输入手机号', trigger: 'blur' }
  53. ],
  54. pass:[
  55. { required: true, message: '请输入密码', trigger: 'blur' }
  56. ],
  57. },
  58. status:true
  59. };
  60. },
  61. directives: {
  62. //监听name input的焦点失去
  63. focus: {
  64. bind(el,node,vm) {
  65. let handle = (e) => {
  66. if(!el.contains(e.target)) {
  67. vm.context.status = true
  68. }
  69. }
  70. el.handle = handle
  71. document.addEventListener('click',handle)
  72. },
  73. unbind(el) {
  74. document.removeEventListener('click',el.handle)
  75. }
  76. }
  77. },
  78. props:['userInfo'],
  79. computed:{
  80. },
  81. watch:{
  82. userInfo: {
  83. handler(val) {
  84. this.ruleForm.name = val.name
  85. this.ruleForm.phonenumber = val.phonenumber
  86. }
  87. },
  88. status: {
  89. handler(val) {
  90. if(!val) {
  91. this.$nextTick(() => {
  92. this.$refs.nameEdit.focus()
  93. })
  94. }
  95. }
  96. }
  97. },
  98. methods: {
  99. save() {
  100. if(this.ruleForm.name == this.userInfo.name) {
  101. this.$notify({
  102. title:'提示',
  103. message:'请输入新的名称',
  104. type:'warning'
  105. })
  106. return
  107. }
  108. this.userInfo.name = this.ruleForm.name
  109. this.status = true
  110. this.edit.content.name = this.ruleForm.name
  111. this.edit.content.phonenumber = this.ruleForm.phonenumber
  112. this.$api.requested(this.edit).then( res => {
  113. if(res.code == 1) {
  114. this.$notify({
  115. title:'提示',
  116. message:'名称修改成功',
  117. type:'success'
  118. })
  119. }
  120. })
  121. }
  122. },
  123. };
  124. </script>
  125. <style scoped>
  126. .base-info {
  127. margin-bottom: 60px;
  128. }
  129. .base-info .title {
  130. font-size: 16px;
  131. font-weight: bold;
  132. color: #333333;
  133. margin-bottom: 30px;
  134. }
  135. .el-input {
  136. width: 500px;
  137. }
  138. /deep/.el-form-item__content {
  139. display: flex;
  140. }
  141. span {
  142. font-size: 14px;
  143. font-weight: 400;
  144. color: #3874F6;
  145. margin-left: 30px;
  146. cursor: pointer;
  147. }
  148. </style>