当前位置: 首页 > wzjs >正文

seo管理系统创作东莞关键词排名快速优化

seo管理系统创作,东莞关键词排名快速优化,联通网站自主备案系统,网络推广品牌营销公司在日常前端开发中,地址选择器是非常常见的功能,尤其是包含“省、市、区”三级联动的组件。借助 china-region 这个库,我们可以非常轻松地实现这一需求,并与 Vue3 组件系统自然集成。本文将带你一步步构建一个带有回显功能的省市区…

在日常前端开发中,地址选择器是非常常见的功能,尤其是包含“省、市、区”三级联动的组件。借助 china-region 这个库,我们可以非常轻松地实现这一需求,并与 Vue3 组件系统自然集成。本文将带你一步步构建一个带有回显功能的省市区选择器。

技术栈

  • Vue 3 + <script setup>
  • TypeScript
  • china-region(省市区数据)
  • 自定义 Select 组件(来自 shadcn-vue,可以根据需要选用)

需求描述

一个三级联动的选择器,用户选择省份后自动加载对应城市,选择城市后再加载对应的区县。更改省级或市级的选择时,其下的选择器也能对应的清空值并且获取新的选取列表。同时支持通过 props 设置默认选中项。


依赖安装

npm install china-region

编写组件

1. 基础数据和 Props 接收

const props = defineProps<{province?: string;city?: string;district?: string;
}>();const provinces = ref(getProvinces());
const selectedProvince = ref(props.province || "");
const selectedCity = ref(props.city || "");
const selectedDistrict = ref(props.district || "");

支持外部传入 默认选中省市区,非常适合做表单回显。


2. 响应式联动逻辑

监听省份,更新城市
watch(selectedProvince, (newProvince) => {selectedCity.value = "";selectedDistrict.value = "";if (newProvince) {// 因为输入框的value被绑定为了地区名称,而getPrefectures函数只接收行政区号,所以这里需要先根据省份名称获取行政区号const provinceCode = getCodeByProvinceName(newProvince);cities.value = getPrefectures(provinceCode);if (props.city) {const targetCity = cities.value.find((city) => city.name === props.city);if (targetCity) selectedCity.value = props.city;}} else {cities.value = [];}
}, { immediate: true });
监听城市,更新区县
watch(selectedCity, (newCity) => {selectedDistrict.value = "";if (newCity) {// china-region没有提供根据城市名获取行政区号的函数,所以只能在cities中查找到与newcity同名的城市的区号const cityCode = cities.value.find((item) => item.name === newCity)?.code;districts.value = getCounties(cityCode);if (props.district) {const targetDistrict = districts.value.find((district) => district.name === props.district,);if (targetDistrict) selectedDistrict.value = props.district;}} else {districts.value = [];}
}, { immediate: true });

3. 输出选中地址

const selectedRegion = computed(() => {
// 可以根据需要返回相对应的数据格式,这里的数据格式为字符串,示例:中国,浙江省,杭州市,西湖区return `中国,${selectedProvince.value},${selectedCity.value},${selectedDistrict.value}`;
});defineExpose({ selectedRegion });

在父组件可以通过 ref 引用组件,拿到完整的地址信息。


模板部分(UI)

<template><div><div class="text-sm">地区选择</div><div class="flex gap-4"><!-- 省 --><Select v-model="selectedProvince"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择省份" /></SelectTrigger><SelectContent class="h-60"><!-- china-region返回的数据结构也支持使用行政区号,这里使用了地区名称--><SelectItemv-for="item in provinces":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select><!-- 市 --><Select v-model="selectedCity" :disabled="!selectedProvince || !cities.length"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择城市" /></SelectTrigger><SelectContent class="h-60"><SelectItemv-for="item in cities":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select><!-- 区 --><Select v-model="selectedDistrict" :disabled="!selectedCity"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择区县" /></SelectTrigger><SelectContent class="max-h-60"><SelectItemv-for="item in districts":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select></div></div>
</template>

这里的样式简单的使用了Tailwind Css,也可以根据需要加入自定义的样式


完整的组件代码

<script setup lang="ts">
import { ref, computed, watch } from "vue";
import {Select,SelectContent,SelectItem,SelectTrigger,SelectValue,
} from "@/components/ui/select";
import {getProvinces,getPrefectures,getCounties,getCodeByProvinceName,
} from "china-region";// 1. 接收父组件的 `props`
const props = defineProps<{province?: string;city?: string;district?: string;
}>();// 2. 省份数据
const provinces = ref(getProvinces());
const selectedProvince = ref(props.province || "");
const selectedCity = ref(props.city || "");
const selectedDistrict = ref(props.district || "");
const cities = ref([]);
const districts = ref([]);// 3. 监听 `selectedProvince`,更新 `cities` 并恢复 `props.city`
watch(selectedProvince,(newProvince) => {selectedCity.value = "";selectedDistrict.value = "";if (newProvince) {const provinceCode = getCodeByProvinceName(newProvince);cities.value = getPrefectures(provinceCode);// 如果 `props.city` 存在,并且 `cities` 里有这个城市,则选中if (props.city) {const targetCity = cities.value.find((city) => city.name === props.city,);if (targetCity) {selectedCity.value = props.city;}}} else {cities.value = [];}},{ immediate: true },
);// 4. 监听 `selectedCity`,更新 `districts` 并恢复 `props.district`
watch(selectedCity,(newCity) => {selectedDistrict.value = "";if (newCity) {const cityCode = cities.value.find((item) => item.name === newCity).code;districts.value = getCounties(cityCode);// 如果 `props.district` 存在,并且 `districts` 里有这个区县,则选中if (props.district) {const targetDistrict = districts.value.find((district) => district.name === props.district,);if (targetDistrict) {selectedDistrict.value = props.district;}}} else {districts.value = [];}},{ immediate: true },
);// 5. 监听 `props` 变化,确保 `props.city` 和 `props.district` 正确赋值
watch(() => props.province,(newVal) => {if (newVal) {selectedProvince.value = newVal;}},
);
watch(() => props.city,(newVal) => {if (newVal && cities.value.some((city) => city.name === newVal)) {selectedCity.value = newVal;}},
);
watch(() => props.district,(newVal) => {if (newVal &&districts.value.some((district) => district.name === newVal)) {selectedDistrict.value = newVal;}},
);// 6. 计算选中的地区
const selectedRegion = computed(() => {return `中国,${selectedProvince.value},${selectedCity.value},${selectedDistrict.value}`;
});// 7. 让父组件可以访问选中的数据
defineExpose({selectedRegion,
});
</script><template><div><div class="text-sm">工作地区</div><!-- 省份选择 --><div class="flex gap-4"><Select v-model="selectedProvince"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择省份" /></SelectTrigger><SelectContent class="h-60"><SelectItemv-for="item in provinces":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select><!-- 城市选择 --><Selectv-model="selectedCity":disabled="!selectedProvince || !cities.length"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择城市" /></SelectTrigger><SelectContent class="h-60"><SelectItemv-for="item in cities":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select><!-- 区县选择 --><Select v-model="selectedDistrict" :disabled="!selectedCity"><SelectTrigger class="w-[100px]"><SelectValue placeholder="请选择区县" /></SelectTrigger><SelectContent class="max-h-60"><SelectItemv-for="item in districts":key="item.name":value="item.name">{{ item.name }}</SelectItem></SelectContent></Select></div></div>
</template>

总结

本组件的优势:

  • 使用 china-region 获取权威行政区域数据;
  • 响应式联动逻辑清晰;
  • 支持外部 props 赋值,方便做表单回显;
  • 使用 defineExpose 暴露接口,增强复用性。

这个组件可以作为表单组件的基础模块,配合表单校验、提交逻辑后非常实用。


这个组件只实现了最简单的三级地区选择以及回显,下一步可以尝试:

  • 添加“清空选择”按钮;
  • 使用 pinia 等状态管理库联动其他表单项。

如果你觉得这篇文章对你有帮助,欢迎点赞收藏!有问题也欢迎留言讨论!

http://www.dtcms.com/wzjs/264810.html

相关文章:

  • 网站建设需要提供什么小程序开发流程详细
  • 单位网站建设与管理产品运营推广方案
  • 自家宽带怎么建设网站重庆seo教程博客
  • 提取卡密网站怎么做关键词推广优化
  • 做外汇网站代理商青岛百度网站排名
  • 天眼查企业查询在线官网经典seo伪原创
  • dw怎么用div css做网站社会化媒体营销
  • 台州本地做网站的求好用的seo软件
  • 温江网站建设seo会被取代吗
  • 太子河网站建设营业推广的方式有哪些
  • 和小孩做的网站seow
  • 福建建设执业资格网站报名系统百度平台商家订单查询
  • 如东网站建设今天上海最新新闻事件
  • 做网站的实验报告如何做好宣传推广
  • 网上开店准备工作seo优化博客
  • 轻设计 让网站灵敏轻便的6个技巧江门搜狗网站推广优化
  • 织梦cms sql注入破解网站后台管理员账号密码企业营销
  • 空间域名一年要多少钱乐陵市seo关键词优化
  • 长沙做网站a微联讯点很好梧州网站seo
  • 怎么做免费公司网站山东百度推广代理
  • 2个女人做暧暧网站竞价代运营公司
  • 东莞做微网站建设网站怎么开发
  • 中小企业网站模板网络营销概述ppt
  • 网站主机查询迅雷磁力
  • 单位建网站公众号推广费用一般多少
  • 鑫菲互动网站建设公司大数据培训机构排名前十
  • 山东网站建设费用全网营销一站式推广
  • 网络科技有限公司官网武汉网优化seo公司
  • 洛阳网站推广公司兰州网站seo
  • 淄博网站建设团队泉州关键词搜索排名