edit.vue 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  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 labelWidth="70">
  25. <up-input v-model="modelForm.telephone" border="none" placeholder="请输入手机号"></up-input>
  26. </up-form-item>
  27. <up-form-item label="地区" prop="area" borderBottom @click="()=> addressShow = true" labelWidth="70">
  28. <pickerAddress @change="addressChange"
  29. :selectValue="[ modelForm.provinceInd, modelForm.cityInd, modelForm.districtInd ]">
  30. <view class="inp"
  31. :class="modelForm.provinceName&&modelForm.cityName&&modelForm.districtName?'':'address-inp'">
  32. {{modelForm.provinceName ? modelForm.provinceName:'省'}} /
  33. {{modelForm.cityName ? modelForm.cityName:'市'}} /
  34. {{modelForm.districtName ? modelForm.districtName:'区'}}
  35. </view>
  36. </pickerAddress>
  37. <template #right>
  38. <up-icon name="map" size="22" @click="onCityWx"></up-icon>
  39. </template>
  40. </up-form-item>
  41. <up-form-item label="地址" prop="address" borderBottom labelWidth="70">
  42. <up-input v-model="modelForm.address" border="none" placeholder="请输入地址"></up-input>
  43. </up-form-item>
  44. </up-form>
  45. <up-action-sheet :show="sexFlag" :actions="sexOptions" @select="sexSelect"
  46. @close="sexFlag = false"></up-action-sheet>
  47. <up-action-sheet :show="labelFlag" :actions="relaTionsHip" @select="sexSelectsHip"
  48. @close="labelFlag = false"></up-action-sheet>
  49. <view class="Wrapper-Btn">
  50. <up-button @click="handleQux" type="error" :plain="true" :hairline="true" text="取消"
  51. :customStyle="hadlClickEdit"></up-button>
  52. <up-button type="error" @click="handleSubmit" text="编辑" :customStyle="hadlClickEdit" />
  53. </view>
  54. </view>
  55. </template>
  56. <script setup>
  57. import {
  58. ref,
  59. reactive,
  60. computed,
  61. } from 'vue';
  62. import {
  63. onLoad
  64. } from '@dcloudio/uni-app';
  65. import {
  66. useraDdress,
  67. } from "@/api/userSettings.js"
  68. // import pickerAddress from '@/components/pickerAddress/pickerAddress.vue' // 地区选择器组件
  69. import pickerAddress from '@/pages_mine/components/pickerAddress/pickerAddress.vue' // 地区选择器组件
  70. import {
  71. splitAddress
  72. } from '@/utils/adress'
  73. const formRef = ref(null)
  74. // 获取页面传递的参数
  75. onLoad((options) => {
  76. if (options) {
  77. options.cityName = decodeURIComponent(decodeURIComponent(options.cityName || ''));
  78. options.districtName = decodeURIComponent(decodeURIComponent(options.districtName || ''));
  79. options.label = decodeURIComponent(decodeURIComponent(options.label || ''));
  80. options.provinceName = decodeURIComponent(decodeURIComponent(options.provinceName || ''));
  81. options.name = decodeURIComponent(decodeURIComponent(options.name || ''));
  82. options.address = decodeURIComponent(decodeURIComponent(options.address || ''));
  83. modelForm.value = {
  84. ...modelForm.value,
  85. ...options,
  86. sex: options.sex ? Number(options.sex) : '',
  87. age: options.age ? Number(options.age) : '',
  88. provinceName: options.provinceName || '',
  89. cityName: options.cityName || '',
  90. districtName: options.districtName || '',
  91. districtCode:options.districtCode,
  92. provinceCode:options.provinceCode
  93. };
  94. }
  95. });
  96. const modelForm = ref({
  97. name: '',
  98. sex: '',
  99. label: '',
  100. age: '',
  101. telephone: '',
  102. provinceName: '', // 省
  103. provinceCode: '',
  104. provinceInd: 0,
  105. cityName: '', // 市
  106. cityCode: '',
  107. cityInd: 0,
  108. districtName: '',
  109. districtCode: '',
  110. districtInd: 0,
  111. address: ''
  112. })
  113. // 回显把provinceName,cityName,districtName字段拼接
  114. const rulesForm = ref({
  115. name: {
  116. type: 'string',
  117. required: true,
  118. message: '请填写姓名',
  119. trigger: ['blur', 'change'],
  120. },
  121. sex: {
  122. type: 'number',
  123. required: true,
  124. message: '请选择性别',
  125. trigger: ['change']
  126. },
  127. label: {
  128. type: 'string',
  129. required: true,
  130. message: '请选择关系',
  131. trigger: ['change'],
  132. },
  133. userInfo: {
  134. type: 'string',
  135. required: true,
  136. message: '请填写年龄',
  137. trigger: ['blur', 'change'],
  138. },
  139. telephone: {
  140. type: 'string',
  141. required: true,
  142. message: '请填写手机号',
  143. trigger: ['blur', 'change'],
  144. },
  145. })
  146. let sexFlag = ref(false)
  147. let labelFlag = ref(false)
  148. let addressShow = ref(false)
  149. let index = ref(0)
  150. const sexOptions = ref([{
  151. name: '男',
  152. value: 0,
  153. }, {
  154. name: '女',
  155. value: 1,
  156. }, ]);
  157. const relaTionsHip = ref([{
  158. name: '父母'
  159. }, {
  160. name: '子女'
  161. },
  162. {
  163. name: '兄弟'
  164. },
  165. {
  166. name: '朋友'
  167. },
  168. {
  169. name: '同学'
  170. },
  171. {
  172. name: '同事'
  173. },
  174. {
  175. name: '配偶'
  176. }
  177. ]);
  178. const displaySex = computed({
  179. get() {
  180. const option = sexOptions.value.find(item => item.value === modelForm.value.sex)
  181. return option ? option.name : ''
  182. },
  183. set(newValue) {
  184. const option = sexOptions.value.find(item => item.name === newValue)
  185. if (option) {
  186. modelForm.value.sex = option.value
  187. }
  188. }
  189. })
  190. // 性别选择处理
  191. function sexSelect(e) {
  192. modelForm.value.sex = e.value; // 确保是 0 或 1
  193. console.log('Selected sex:', e.value, 'Model sex:', modelForm.value.sex);
  194. sexFlag.value = false;
  195. // 手动触发验证
  196. formRef.value.validateField('sex');
  197. }
  198. function sexSelectsHip(e) {
  199. modelForm.value.label = e.name;
  200. labelFlag.value = false;
  201. }
  202. function addressChange(info) {
  203. console.log('地区选择器返回的完整数据:', info);
  204. console.log('地区编码:', info.code);
  205. if (!info || !info.data) {
  206. console.error('Invalid address change info:', info);
  207. return;
  208. }
  209. if (!Array.isArray(info.data) || info.data.length < 3) {
  210. console.error('Invalid address data:', info.data);
  211. return;
  212. }
  213. const code = Array.isArray(info.code) ? info.code : ['', '', ''];
  214. let indexArray;
  215. if (Array.isArray(info.index)) {
  216. indexArray = info.index;
  217. } else if (info.index && typeof info.index[Symbol.iterator] === 'function') {
  218. indexArray = Array.from(info.index);
  219. } else {
  220. indexArray = [0, 0, 0];
  221. }
  222. modelForm.value.provinceName = info.data[0] || '';
  223. modelForm.value.provinceCode = code[0] || '';
  224. modelForm.value.provinceInd = indexArray[0] || 0;
  225. modelForm.value.cityName = info.data[1] || '';
  226. modelForm.value.cityCode = code[1] || '';
  227. modelForm.value.cityInd = indexArray[1] || 0;
  228. modelForm.value.districtName = info.data[2] || '';
  229. modelForm.value.districtCode = code[2] || '';
  230. modelForm.value.districtInd = indexArray[2] || 0;
  231. }
  232. function onCityWx(row) {
  233. console.log('地区选点', row);
  234. wx.chooseLocation({
  235. success: function(res) {
  236. const result = splitAddress(res.address);
  237. console.log(res, result);
  238. modelForm.value.provinceName = result.province
  239. modelForm.value.cityName = result.city
  240. modelForm.value.districtName = result.district
  241. modelForm.value.address = result.detail
  242. modelForm.value.longitude = res.longitude
  243. modelForm.value.latitude = res.latitude
  244. },
  245. fail: function(err) {
  246. console.log(err);
  247. uni.showToast({
  248. title: '获取地址失败',
  249. icon: 'error',
  250. });
  251. },
  252. })
  253. }
  254. // 提交编辑
  255. async function handleSubmit() {
  256. try {
  257. // 1. 验证表单
  258. await formRef.value.validate();
  259. // 2. 准备提交数据
  260. const submitData = {
  261. ...modelForm.value,
  262. sex: modelForm.value.sex,
  263. };
  264. // 3. 显示加载中提示(可选)
  265. uni.showLoading({
  266. title: '提交中...',
  267. mask: true
  268. });
  269. // 4. 调用接口
  270. const response = await useraDdress(submitData);
  271. // 5. 隐藏加载中
  272. uni.hideLoading();
  273. // 6. 处理响应
  274. if (response.code === 200) {
  275. await new Promise((resolve) => {
  276. uni.showToast({
  277. title: '编辑成功',
  278. icon: 'success',
  279. duration: 1500, // 默认1500ms
  280. mask: true,
  281. success: () => {
  282. // 等待Toast显示完成
  283. setTimeout(() => resolve(), 1500);
  284. }
  285. });
  286. });
  287. // 7. 跳转页面
  288. uni.navigateTo({
  289. url: '/pages_mine/pages/selectAddress/index'
  290. });
  291. } else {
  292. uni.showToast({
  293. title: response.msg || '编辑失败',
  294. icon: 'none'
  295. });
  296. }
  297. } catch (error) {
  298. uni.hideLoading();
  299. console.error('编辑失败', error);
  300. uni.showToast({
  301. title: '编辑失败: ' + (error.message || '未知错误'),
  302. icon: 'none'
  303. });
  304. }
  305. }
  306. const handleQux = () => {
  307. uni.navigateBack({
  308. delta: -1
  309. })
  310. }
  311. const hadlClickEdit = {
  312. width: '240rpx',
  313. marginTop: '30rpx'
  314. }
  315. </script>
  316. <style scoped>
  317. .Wrapper-Btn {
  318. display: flex;
  319. justify-content: center;
  320. align-items: center;
  321. }
  322. </style>