123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- <template>
- <view class="address-main">
- <pickerAddress @change="(info) => addressChange(info, item)"
- :selectValue="[formData.provinceInd, formData.cityInd, formData.districtInd]"
- style="width: 100%;"
- >
- <view
- class="inp"
- :class="formData.provinceName && formData.cityName && formData.districtName ? 'form-input' : 'form-placeholder'">
- {{ addressValue }}
- </view>
- </pickerAddress>
- <view class="icon-address" @click="onCityWx"></view>
- </view>
- </template>
- <script setup>
- import { reactive, ref,inject } from "vue";
- import { splitAddress, getCityCode, getAdressCode } from '@/utils/adress'
- import { regionAddresstree } from '@/api/home.js'
- import pickerAddress from '../../components/pickerAddress/pickerAddress.vue'
- import { computed } from "vue";
- const formData = inject('formData');
- const props = defineProps({
- column: {
- type: Array,
- default: [],
- },
- isCode: {
- type: Boolean,
- default: true
- }
- });
- // const formData = reactive({
- // sex: null,
- // city: null,
- // provinceName: '', // 省
- // provinceCode: '',
- // provinceInd: 21,
- // cityName: '', // 市
- // cityCode: '',
- // cityInd: 0,
- // districtName: '',
- // districtCode: '',
- // districtInd: 17,
- // });
- const addressValue = computed(() => {
- if (formData.provinceName && formData.cityName && formData.districtName) {
- return [formData.provinceName, formData.cityName, formData.districtName].join('/');
- }
- return '请填写所在区域'
- })
- function addressChange(info) {
- console.log(info, '>>>>data');
- if (!info || !info.data) {
- console.error('Invalid address change info:', info);
- return;
- }
- if (!Array.isArray(info.data) || info.data.length < 3) {
- console.error('Invalid address data:', info.data);
- return;
- }
- const code = Array.isArray(info.code) ? info.code : ['', '', ''];
- let indexArray;
- if (Array.isArray(info.index)) {
- indexArray = info.index;
- } else if (info.index && typeof info.index[Symbol.iterator] === 'function') {
- indexArray = Array.from(info.index);
- } else {
- indexArray = [0, 0, 0];
- }
- Object.assign(formData, {
- provinceName: info.data[0],
- provinceCode: info.code[0],
- provinceInd: indexArray[0] || 0,
- cityName: info.data[1],
- cityCode: info.code[1],
- cityInd: indexArray[1] || 0,
- districtName: info.data[2],
- districtCode: info.code[2],
- districtInd: indexArray[2] || 0
- })
- console.log('formData===>', formData);
- }
- function onCityWx() {
- console.log('地区选点');
- wx.chooseLocation({
- success: async function (res) {
- console.log('res.address', res);
- const result = splitAddress(res.address);
- const res_dara = await regionAddresstree();
- const handlecityData = getCityCode([result.province, result.city, result.district].join(' '), res_dara.data)
- const api_res = await getAdressCode({ latitude: res.latitude, longitude: res.longitude }, res_dara.data)
- console.log("=================>", handlecityData, api_res)
- addressChange(api_res.cityCode)
- Object.assign(formData, {
- address: result.detail
- })
- },
- fail: function (err) {
- console.log(err);
- uni.showToast({
- title: '获取地址失败',
- icon: 'error',
- });
- },
- })
- }
- </script>
- <style lang="scss" scoped>
- .address-main{
- display: flex;
- align-items: center;
- justify-content: space-between;
- width: 100%;
- .inp {
- flex: 1;
- }
- }
- .form-input {
- flex: 1;
- font-family: PingFang SC;
- font-size: 32rpx;
- line-height: 44rpx;
- color: #130F26;
- }
- .form-placeholder {
- color: #C9CDD4;
- }
- .icon-address {
- width: 36rpx;
- height: 36rpx;
- background-image: url();
- background-position: center;
- background-size: 36rpx auto;
- background-repeat: no-repeat;
- // margin-right: 32rpx;
- }
- </style>
|