edit.vue 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <template>
  2. <view>
  3. <up-form labelPosition="left" :model="modelForm" :rules="rulesForm" ref="formRef">
  4. <up-form-item label="姓名" prop="name" borderBottom labelWidth="70">
  5. <up-input v-model="modelForm.name" border="none" placeholder="请输入姓名"></up-input>
  6. </up-form-item>
  7. <up-form-item label="性别" prop="sex" borderBottom @click="() => (sexFlag = true)" labelWidth="70">
  8. <up-input v-model="displaySex" disabled disabledColor="#ffffff" placeholder="请选择性别"
  9. border="none"></up-input>
  10. <template #right>
  11. <up-icon name="arrow-right"></up-icon>
  12. </template>
  13. </up-form-item>
  14. <up-form-item label="关系" prop="label" borderBottom @click="() => labelFlag = true" labelWidth="70">
  15. <up-input v-model="modelForm.label" disabled disabledColor="#ffffff" placeholder="请选择关系"
  16. border="none"></up-input>
  17. <template #right>
  18. <up-icon name="arrow-right"></up-icon>
  19. </template>
  20. </up-form-item>
  21. <up-form-item label="年龄" prop="age" borderBottom labelWidth="70">
  22. <up-input v-model="modelForm.age" border="none" placeholder="请输入年龄"></up-input>
  23. </up-form-item>
  24. <up-form-item label="手机号" prop="telephone" borderBottom
  25. :style="{ display: 'flex', justifyContent: 'space-between', alignItems: 'center' }" labelWidth="70">
  26. <up-input v-model="modelForm.telephone" border="none" placeholder="请输入手机号"></up-input>
  27. </up-form-item>
  28. <up-form-item label="是否有传染疾病" prop="isContagion" borderBottom labelWidth="150">
  29. <up-radio-group v-model="modelForm.isContagion" placement="row" @change="handleContagionChange">
  30. <up-radio :customStyle="{marginRight: '16px'}" v-for="(item, index) in isContagionOption"
  31. :key="index" :label="item.name" :name="item.key"></up-radio>
  32. </up-radio-group>
  33. </up-form-item>
  34. <up-form-item v-show="showContagionContent" label="传染病内容" prop="haveContagion" borderBottom
  35. labelWidth="100">
  36. <up-input v-model="modelForm.haveContagion" border="none" placeholder="请输入传染病内容"></up-input>
  37. </up-form-item>
  38. <up-form-item label="地区" prop="area" borderBottom @click="()=> addressShow = true" labelWidth="70">
  39. <pickerAddress @change="addressChange"
  40. :selectValue="[ modelForm.provinceInd, modelForm.cityInd, modelForm.districtInd ]">
  41. <view class="inp"
  42. :class="modelForm.provinceName&&modelForm.cityName&&modelForm.districtName?'':'address-inp'">
  43. {{modelForm.provinceName ? modelForm.provinceName:'省'}} /
  44. {{modelForm.cityName ? modelForm.cityName:'市'}} /
  45. {{modelForm.districtName ? modelForm.districtName:'区'}}
  46. </view>
  47. </pickerAddress>
  48. <template #right>
  49. <up-icon name="arrow-right"></up-icon>
  50. </template>
  51. </up-form-item>
  52. <up-form-item label="地址" prop="address" borderBottom labelWidth="70">
  53. <up-input v-model="modelForm.address" border="none" placeholder="请输入地址"></up-input>
  54. </up-form-item>
  55. </up-form>
  56. <up-action-sheet :show="sexFlag" :actions="sexOptions" @select="sexSelect"
  57. @close="sexFlag = false"></up-action-sheet>
  58. <up-action-sheet :show="labelFlag" :actions="relaTionsHip" @select="sexSelectsHip"
  59. @close="labelFlag = false"></up-action-sheet>
  60. <up-button type="primary" @click="handleSubmit" text="编辑" style="margin: 30rpx;" />
  61. </view>
  62. </template>
  63. <script setup>
  64. import {
  65. ref,
  66. reactive,
  67. computed,
  68. } from 'vue';
  69. import {
  70. onLoad
  71. } from '@dcloudio/uni-app';
  72. import {
  73. useraDdress,
  74. } from "@/api/userSettings.js"
  75. import pickerAddress from '@/components/pickerAddress/pickerAddress.vue' // 地区选择器组件
  76. const formRef = ref(null)
  77. // 获取页面传递的参数
  78. // 获取页面传递的参数
  79. onLoad((options) => {
  80. console.log(options, '》》》》》》》》》》》》// 检查传递的参数');
  81. // 对每个字段进行解码(如果编码过两次)
  82. if (options) {
  83. options.cityName = decodeURIComponent(decodeURIComponent(options.cityName || ''));
  84. options.districtName = decodeURIComponent(decodeURIComponent(options.districtName || ''));
  85. options.label = decodeURIComponent(decodeURIComponent(options.label || ''));
  86. options.provinceName = decodeURIComponent(decodeURIComponent(options.provinceName || ''));
  87. options.name = decodeURIComponent(decodeURIComponent(options.name || ''));
  88. options.address = decodeURIComponent(decodeURIComponent(options.address || ''));
  89. options.haveContagion = decodeURIComponent(decodeURIComponent(options.haveContagion || ''));
  90. modelForm.value = {
  91. ...modelForm.value,
  92. ...options,
  93. sex: options.sex ? Number(options.sex) : '',
  94. age: options.age ? Number(options.age) : '',
  95. isContagion: options.isContagion ? Number(options.isContagion) : '',
  96. provinceName: options.provinceName || '',
  97. cityName: options.cityName || '',
  98. districtName: options.districtName || '',
  99. };
  100. showContagionContent.value = options.isContagion === 1;
  101. }
  102. });
  103. const modelForm = ref({
  104. name: '',
  105. sex: '',
  106. label: '',
  107. age: '',
  108. telephone: '',
  109. isContagion: '',
  110. haveContagion: '',
  111. provinceName: '', // 省
  112. provinceCode: '',
  113. provinceInd: 0,
  114. cityName: '', // 市
  115. cityCode: '',
  116. cityInd: 0,
  117. districtName: '',
  118. districtCode: '',
  119. districtInd: 0,
  120. address: ''
  121. })
  122. // 回显把provinceName,cityName,districtName字段拼接
  123. const rulesForm = ref({
  124. name: {
  125. type: 'string',
  126. required: true,
  127. message: '请填写姓名',
  128. trigger: ['blur', 'change'],
  129. },
  130. sex: {
  131. type: 'number',
  132. required: true,
  133. message: '请选择性别',
  134. trigger: ['change']
  135. },
  136. label: {
  137. type: 'string',
  138. required: true,
  139. message: '请选择关系',
  140. trigger: ['change'],
  141. },
  142. userInfo: {
  143. type: 'string',
  144. required: true,
  145. message: '请填写年龄',
  146. trigger: ['blur', 'change'],
  147. },
  148. telephone: {
  149. type: 'string',
  150. required: true,
  151. message: '请填写手机号',
  152. trigger: ['blur', 'change'],
  153. },
  154. })
  155. let sexFlag = ref(false)
  156. let labelFlag = ref(false)
  157. let addressShow = ref(false)
  158. let index = ref(0)
  159. // 新增一个响应式变量,控制传染病内容的显示
  160. const showContagionContent = ref(false);
  161. const sexOptions = ref([{
  162. name: '男',
  163. value: 0,
  164. }, {
  165. name: '女',
  166. value: 1,
  167. }, ]);
  168. const isContagionOption = ref([{
  169. name: '是',
  170. key: 1,
  171. disabled: false,
  172. },
  173. {
  174. name: '否',
  175. key: 0,
  176. disabled: false,
  177. }
  178. ])
  179. const relaTionsHip = ref([{
  180. name: '父母'
  181. }, {
  182. name: '子女'
  183. },
  184. {
  185. name: '兄弟'
  186. },
  187. {
  188. name: '朋友'
  189. },
  190. {
  191. name: '同学'
  192. },
  193. {
  194. name: '同事'
  195. },
  196. {
  197. name: '配偶'
  198. }
  199. ]);
  200. const displaySex = computed({
  201. get() {
  202. const option = sexOptions.value.find(item => item.value === modelForm.value.sex)
  203. return option ? option.name : ''
  204. },
  205. set(newValue) {
  206. const option = sexOptions.value.find(item => item.name === newValue)
  207. if (option) {
  208. modelForm.value.sex = option.value
  209. }
  210. }
  211. })
  212. // 性别选择处理
  213. function sexSelect(e) {
  214. modelForm.value.sex = e.value; // 确保是 0 或 1
  215. console.log('Selected sex:', e.value, 'Model sex:', modelForm.value.sex);
  216. sexFlag.value = false;
  217. // 手动触发验证
  218. formRef.value.validateField('sex');
  219. }
  220. function sexSelectsHip(e) {
  221. modelForm.value.label = e.name;
  222. labelFlag.value = false;
  223. }
  224. function addressChange(info) {
  225. console.log(info, '>>>>data');
  226. const {
  227. data,
  228. code,
  229. index
  230. } = info
  231. modelForm.value.provinceName = data[0]
  232. modelForm.value.provinceCode = code[0]
  233. modelForm.value.provinceInd = index[0]
  234. modelForm.value.cityName = data[1]
  235. modelForm.value.cityCode = code[1]
  236. modelForm.value.cityInd = index[1]
  237. modelForm.value.districtName = data[2]
  238. modelForm.value.districtCode = code[2]
  239. modelForm.value.districtInd = index[2]
  240. }
  241. // 提交编辑
  242. async function handleSubmit() {
  243. try {
  244. // 验证表单
  245. await formRef.value.validate();
  246. // 准备提交数据
  247. const submitData = {
  248. ...modelForm.value,
  249. // 确保提交的数据格式正确
  250. sex: modelForm.value.sex,
  251. isContagion: modelForm.value.isContagion,
  252. // 其他需要处理的数据...
  253. };
  254. // 调用编辑接口
  255. const response = await useraDdress(submitData);
  256. // 处理响应
  257. if (response.code === 200) {
  258. uni.showToast({
  259. title: '编辑成功',
  260. icon: 'success'
  261. });
  262. // 返回上一页或其他操作
  263. uni.navigateBack();
  264. } else {
  265. uni.showToast({
  266. title: response.msg || '编辑失败',
  267. icon: 'none'
  268. });
  269. }
  270. } catch (error) {
  271. console.error('编辑失败', error);
  272. uni.showToast({
  273. title: '编辑失败',
  274. icon: 'none'
  275. });
  276. }
  277. }
  278. </script>
  279. <style>
  280. </style>