Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Address组件无法根据所选择的province,city,country动态加载对应的city,country,town #2676

Open
Astrsea opened this issue Nov 20, 2023 · 2 comments
Labels
PR Welcome 已确认存在的问题,或者计划实现的功能,欢迎社区 PR

Comments

@Astrsea
Copy link

Astrsea commented Nov 20, 2023

NutUI 包名

@nutui/nutui-taro

NutUI 版本号

4.2.1

平台

weapp

重现链接

https://nutui.jd.com/playground/#{"App.vue":"<template>\n  <nut-cell title=\"选择地址\" :desc=\"text\" is-link @click=\"showAddress\"></nut-cell>\n  <nut-address\n      v-model=\"value\"\n      :visible=\"showPopup\"\n      :province=\"provinces\"\n      :city=\"cities\"\n      :country=\"countries\"\n      :town=\"towns\"\n      @change=\"onChange\"\n      @close=\"close\"\n      @select=\"selected\"\n      custom-address-title=\"请选择所在地区\"\n      :columns-placeholder=\"placeholder\"\n  ></nut-address>\n  <BottomTabbar></BottomTabbar>\n</template>\n\n<script setup lang=\"ts\">\nimport BottomTabbar from \"../../components/BottomTabbar.vue\";\nimport { ref } from 'vue';\nimport {RegionData} from \"@nutui/nutui-taro/dist/types/__VUE/address/type\";\nconst showPopup = ref(false);\nlet provinces = new Array<RegionData>;\nlet cities = new Array<RegionData>;\nlet countries = new Array<RegionData>;\nlet towns = new Array<RegionData>;\n\nconst text = ref('北京朝阳区八里庄街道')\nconst value = ref([]);\n  \nconst data = [{\n            code: \"110000\",\n            city: [\n                {\n                    code: \"110100\",\n                    country: [\n                        {\n                            code: \"110101\",\n                            title: \"东城区\"\n                        },\n                        {\n                            code: \"110102\",\n                            title: \"西城区\"\n                        },\n                        {\n                            code: \"110105\",\n                            title: \"朝阳区\"\n                        },\n                        {\n                            code: \"110106\",\n                            title: \"丰台区\"\n                        },\n                        {\n                            code: \"110107\",\n                            title: \"石景山区\"\n                        },\n                        {\n                            code: \"110108\",\n                            title: \"海淀区\"\n                        },\n                        {\n                            code: \"110109\",\n                            title: \"门头沟区\"\n                        },\n                        {\n                            code: \"110111\",\n                            title: \"房山区\"\n                        },\n                        {\n                            code: \"110112\",\n                            title: \"通州区\"\n                        },\n                        {\n                            code: \"110113\",\n                            title: \"顺义区\"\n                        },\n                        {\n                            code: \"110114\",\n                            title: \"昌平区\"\n                        },\n                        {\n                            code: \"110115\",\n                            title: \"大兴区\"\n                        },\n                        {\n                            code: \"110116\",\n                            title: \"怀柔区\"\n                        },\n                        {\n                            code: \"110117\",\n                            title: \"平谷区\"\n                        },\n                        {\n                            code: \"110118\",\n                            title: \"密云区\"\n                        },\n                        {\n                            code: \"110119\",\n                            title: \"延庆区\"\n                        }\n                    ],\n                    title: \"市辖区\"\n                }\n            ],\n            title: \"北京市\"\n        },{\n            code: \"120000\",\n            city: [\n                {\n                    code: \"120100\",\n                    country: [\n                        {\n                            code: \"120101\",\n                            title: \"和平区\"\n                        },\n                        {\n                            code: \"120102\",\n                            title: \"河东区\"\n                        },\n                        {\n                            code: \"120103\",\n                            title: \"河西区\"\n                        },\n                        {\n                            code: \"120104\",\n                            title: \"南开区\"\n                        },\n                        {\n                            code: \"120105\",\n                            title: \"河北区\"\n                        },\n                        {\n                            code: \"120106\",\n                            title: \"红桥区\"\n                        },\n                        {\n                            code: \"120110\",\n                            title: \"东丽区\"\n                        },\n                        {\n                            code: \"120111\",\n                            title: \"西青区\"\n                        },\n                        {\n                            code: \"120112\",\n                            title: \"津南区\"\n                        },\n                        {\n                            code: \"120113\",\n                            title: \"北辰区\"\n                        },\n                        {\n                            code: \"120114\",\n                            title: \"武清区\"\n                        },\n                        {\n                            code: \"120115\",\n                            title: \"宝坻区\"\n                        },\n                        {\n                            code: \"120116\",\n                            title: \"滨海新区\"\n                        },\n                        {\n                            code: \"120117\",\n                            title: \"宁河区\"\n                        },\n                        {\n                            code: \"120118\",\n                            title: \"静海区\"\n                        },\n                        {\n                            code: \"120119\",\n                            title: \"蓟州区\"\n                        }\n                    ],\n                    title: \"市辖区\"\n                }\n            ],\n            title: \"天津市\"\n        }];\n\nconst showAddress = () => {\n  showPopup.value = !showPopup.value;\n  data.forEach((province)=>{\n    provinces.push({\n      id:province.code,\n      name:province.title,\n      city:province.city\n    })\n  });\n};\n\n\nconst onChange = (cal) => {\n  if (cal.next == \"province\"){\n    cal.value.forEach((city)=>{\n      cities.push({\n        id:city.code,\n        name:city.title,\n        country:city.country\n      })\n    })\n    if (cities.length < 1){\n      showPopup.value = false;\n    }\n  }else if (cal.next == \"country\"){\n    cal.value.forEach((country)=>{\n      countries.push({\n        id:country.code,\n        name:country.title,\n      })\n    })\n    if (countries.length < 1){\n      showPopup.value = false;\n    }\n  }\n};\n\n</script>\n\n<style lang=\"scss\">\n</style>\n\n\n"}

重现步骤

###选择省份后,观察市是否动态加载

期望的结果是什么?

选择对应的省后加载省下方对应的市,选择市后动态加载区

实际的结果是什么?

选择省后市无法动态加载,并且出现空值的现象

环境信息

No response

其他补充信息

No response

@xiangBiaoOne
Copy link

这个问题我也遇到了之前版本4.1.6没问题,升级到了4.2.0也出现了这个bug。@change的回掉参数只返回了一个{
"custom": "province"
}.。next和value没有返回,这个bug很严重

@eiinu eiinu self-assigned this Nov 21, 2023
@eiinu eiinu modified the milestone: v4.2.2 Nov 21, 2023
@xiangBiaoOne
Copy link

这个问题虽然解决了,但是不完美。
在选择省的时候,市和区的数组需要一个初始值,给个空数组会选择了省控件就关闭了。
需要这样写:
const address = reactive({
placeholder: placeholder,
province: [{}],
city: [{}],
country: [{}],
town: []
});

@eiinu eiinu removed their assignment Nov 28, 2023
@eiinu eiinu added the PR Welcome 已确认存在的问题,或者计划实现的功能,欢迎社区 PR label Nov 28, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
PR Welcome 已确认存在的问题,或者计划实现的功能,欢迎社区 PR
Projects
None yet
Development

No branches or pull requests

3 participants