"利用React自定义Hook管理地名数据:一次简洁实践"

使用自定义Hook获取地名数据

在日常的前端开发中,很多时候我们需要处理类似的逻辑或者数据结构。这时,React的自定义Hook为我们提供了一种优雅的解决方案。今天,我们将探讨如何使用自定义Hook来获取和管理地名数据。

基本概念

首先,为了更好地理解,我们需要有一个基本概念。在我们的案例中,我们希望获取中国的省、市、区数据。我们将根据所提供的PlaceType来获取相应的地名。

实现

tsx 复制代码
/**
 * 自定义Hook,基于所提供的PlaceType获取地名。
 *
 * @param {string} PlaceType - 查询的地点类型。默认为空字符串。
 * @returns {object} 包含省份数据、城市数据、区域数据以及获取城市和区域数据的函数的对象。
 */
function useGetPlaceName(PlaceType: 'td' | '' = ''): {
  provinceData: PlaceNameProps[];
  cityData: PlaceNameProps[];
  areaData: PlaceNameProps[];
  getCityAndArea: (key: string, type: 'city' | 'area') => void;
} {
  // 省、市、区的数据状态
  const [provinceData, setProvinceData] = useState<PlaceNameProps[]>([]);
  const [cityData, setCityData] = useState<PlaceNameProps[]>([]);
  const [areaData, setAreaData] = useState<PlaceNameProps[]>([]);
  const [CnData, setCnData] = useState<Record<string, unknown>[]>([]);

  /**
   * 根据PlaceType获取和处理城市数据。
   */
  useEffect(() => {
    queryCity(PlaceType).then((res) => {
      if (res) {
        const CnList = PlaceType === 'td' ? res['10045'] : res['86'];
        const tmpData = Object.entries(CnList).map(([key, value]) => ({ key, value }));
        setProvinceData(tmpData);
        setCnData(res);
      }
    });
  }, [PlaceType]);

  /**
   * 根据提供的key和type获取和处理城市或区域数据。
   *
   * @param {string} provinceKey - 省份的键。
   * @param {'city' | 'area'} type - 要获取的数据类型,城市或区域。
   */
  const getCityAndArea = (provinceKey: string, type: 'city' | 'area') => {
    const dataSubset = CnData[String(provinceKey)];
    const tmpData = Object.entries(dataSubset).map(([key, value]) => ({ key, value }));
    
    if (type === 'city') setCityData(tmpData);
    else if (type === 'area') setAreaData(tmpData);
  };

  return { provinceData, cityData, areaData, getCityAndArea };
}

export { useGetPlaceName };

我们首先导入了必要的hooks------useStateuseEffect

详细分析

  1. useState的初始化

我们定义了四个状态:provinceData, cityData, areaDataCnData,用于存储省、市、区的数据和整体数据。

  1. useEffect的作用

useEffect保证了当PlaceType发生变化时,我们的数据会重新查询。在内部,我们通过调用queryCity函数获取数据,并对数据进行处理,最后更新到我们的状态中。

  1. getCityAndArea 函数

这个函数的目的是获取特定省份的城市或区域数据。根据提供的provinceKey和类型(城市或区域),它处理并更新相应的状态。

结论

通过使用自定义Hook,我们可以更加模块化地管理和处理地名数据,从而使代码更加清晰和可维护。这只是自定义Hook的一个小示例,但希望这能帮助你看到其强大的功能和在日常开发中的潜在应用。

相关推荐
果然1232 分钟前
Vue 3 Composition API 最佳实践:从项目实战中汲取的经验
前端
鱼人34 分钟前
Web Components:未来的前端组件化标准?
前端
果汁华38 分钟前
Chrome DevTools MCP:让 AI 编码助手拥有浏览器调试超能力
前端·人工智能·chrome devtools
二月龙1 小时前
移动端适配必杀技:Viewport与响应式布局全解
前端
大萝卜呼呼1 小时前
Next.js第十七课 - 部署
前端·typescript·next.js
只会写Bug1 小时前
后台管理项目中关于新增、编辑弹框使用的另一种展示形式
前端·vue.js
weixin199701080161 小时前
《废旧物资商品详情页前端性能优化实战》
前端·性能优化
用户52709648744901 小时前
Vite 开发代理里的 `ws` 是什么,什么时候该开
前端
冰水不凉1 小时前
robot_localization实现imu和odom融合
前端·slam
M ? A2 小时前
Vue v-bind 转 React:VuReact 怎么处理?
前端·javascript·vue.js·经验分享·react.js·面试·vureact