React组件 -- ListSelect

封装一个名为ListSelect的组件,其作用为从后端接口获取数据然后渲染成选项。同时,支持国际化和禁用;它是一个受控组件,受控体现在Select组件的onChange和value属性上面。

接口定义

  • IItem:选项格式的接口类型,包含idvalue属性。
  • IProps:组件的props格式,包含valuehandleChangedisabled属性。
  • IResult:接口返回格式的类型,包含datasuccess属性。

组件构造

  • 使用useState定义一个source变量,用于保存Select的原始数据。
  • 使用useEffect钩子在组件挂载和更新时发送网络请求,并使用setState更新source的值。
  • 在组件返回值中使用Ant Design的Select组件,并传入属性:
    • onChange:绑定props.handleChange回调函数,用于选项变化时通知父组件。
    • disabled:绑定props.disabled,表示是否禁用。
    • placeholder:使用getIntl方法获取国际化的占位符。
    • value:使用props.value,表示当前选中的值。
  • 使用source数组的map方法生成Option组件,每个Option组件的值和展示内容分别使用item.iditem.value

组件内容

tsx 复制代码
import React, { useState, useEffect } from 'react';
import { Select } from 'antd';
import { request, getIntl } from '../utils';
const { Option } = Select;

// 选项格式
type IItem = {
  id:string;
  value:string;
}

// props格式
interface IProps {
  value: string,
  handleChange: (e:any)=>any,
  disabled: boolean,
}

// 接口返回格式
interface IResult {
  data: Array<IItem>,
  success: boolean,
}

// 封装的组件
const ListSelect = (props: IProps) => {
  // 渲染Select的原始数据
  const [source, setSource] = useState<IItem[]>([]);

  // 在useEffect中发起网络请求,并在回调中通过setState更新列表值
  useEffect(() => {
    request.get('/**/*/list').then((res: IResult) => {
      const { data, success } = res;
      if (success) {
        setSource(data);
      }
    });
  }, []);

  // 渲染Select
  return (
    <Select
      onChange={props?.handleChange} // 选中后通知调用者的回调
      disabled={props.disabled} // 由调用者决定是否可用
      placeholder={getIntl('Common.PleaseSelect')} // 国际化的占位符
      value={props.value} // 组件受控,使用onChange和value搭配之后的数据流向为:选项被选中,触发onChange进而触发传入的handleChange引起调用组件中相应值变化,导致传入的value值发生变化,组件重新渲染
    >
      {source &&
        source.length > 0 &&
        source.map(item => {
          return (
            <Option value={item.id} key={item.value}>
              {item.value}
            </Option>
          );
        })}
    </Select>
  );
};

export { ListSelect };
相关推荐
xjt_090111 分钟前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农22 分钟前
Vue 2.3
前端·javascript·vue.js
夜郎king1 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
辰风沐阳1 小时前
JavaScript 的宏任务和微任务
javascript
夏幻灵2 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星2 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_2 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝2 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions2 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法