React的组件封装

前言

最近开始学习React,跟着Nolan老师开发Jira,有很多干货,这里分享一个组件封装的方法。

一、需求分析

在antd的Select组件中,

  • value 可以传入多种类型的值
  • onChange只会回调 number|undefined 类型
  • 当 isNaN(Number(value)) 为true的时候,也就是vaule不能转换成number的时候,代表选择默认类型,就是string
  • 当选择默认类型的时候,onChange会回调undefined

这个需求是因为在select组件中,我们希望把id转换成number的形式,满足接口

export interface User {
  id: number;
 }

二、实现细节

2.1 新加的功能

我们需要在IdSelect组件中传入value, defaultOptionName以及OnChange方法,其它保留原有antd的select提供的属性

interface IdSelectProps extends Omit<SelectProps, 'value' | 'onChange' | 'options'> {
  value: string|number|null|undefined
  onChange: (value?: number) => void
  defaultOptionName?: string
  options?: {name: string; id: number}[]
}

2.2 增强的方法

vaule不能转换成number的时候,代表选择默认类型,onChange回调undefined

onChange={selectedValue=>onChange(toNumber(selectedValue) || undefined)}

const toNumber = (value: unknown) => (isNaN(Number(value)) ? 0 : Number(value));

2.3 最终的组件

type SelectProps = React.ComponentProps<typeof Select>

interface IdSelectProps extends Omit<SelectProps, 'value' | 'onChange' | 'options'> {
  value: Raw | null| undefined
  onChange: (value?: number) => void
  defaultOptionName?: string
  options?: {name: string; id: number}[]
}

/**
 * value 可以传入多种类型的值
 * onChange只会回调 number|undefined 类型
 * 当 isNaN(Number(value)) 为true的时候,代表选择默认类型
 * 当选择默认类型的时候,onChange会回调undefined
 * @param props
 * @constructor
 */
export const IdSelect = (props: IdSelectProps) => {
  const {value, onChange, defaultOptionName, options, ...restProps} = props
  return(
    <Select
      value={toNumber(value)}
      onChange={selectedValue=>onChange(toNumber(selectedValue) || undefined)}
      {...restProps}
    >
      {defaultOptionName ? (
        <Select.Option value={0}>{defaultOptionName}</Select.Option>
      ) : null}
      {options?.map((option) => (
        <Select.Option key={option.id} value={option.id}>
          {option.name}
        </Select.Option>
      ))}
    </Select>
  )
};

const toNumber = (value: unknown) => (isNaN(

总结

React给了前端很多抽象以及封装的功能,如果多加以利用,可以使得代码复用性变得更好。对于需要增强组件的方法可以让组件更加符合需求

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React 组件封装成 Hook 可以让我们更方便地在函数组件中复用组件逻辑。下面是一些封装组件为 Hook 的示例代码: 1. 使用 useState 封装计数器组件: ```javascript import { useState } from 'react'; const useCounter = (initialCount = 0, step = 1) => { const [count, setCount] = useState(initialCount); const increment = () => setCount(count + step); const decrement = () => setCount(count - step); return { count, increment, decrement }; }; export default useCounter; ``` 使用示例: ```javascript import useCounter from './useCounter'; function Counter() { const { count, increment, decrement } = useCounter(); return ( <> <p>Count: {count}</p> <button onClick={increment}>+</button> <button onClick={decrement}>-</button> </> ); } ``` 2. 使用 useEffect 封装鼠标位置跟踪组件: ```javascript import { useState, useEffect } from 'react'; const useMousePosition = () => { const [position, setPosition] = useState({ x: 0, y: 0 }); useEffect(() => { const updateMousePosition = (event) => { setPosition({ x: event.clientX, y: event.clientY }); }; document.addEventListener('mousemove', updateMousePosition); return () => { document.removeEventListener('mousemove', updateMousePosition); }; }, []); return position; }; export default useMousePosition; ``` 使用示例: ```javascript import useMousePosition from './useMousePosition'; function MouseTracker() { const { x, y } = useMousePosition(); return ( <p> Mouse position: {x}, {y} </p> ); } ``` 以上是两个简单的示例,通过封装 React 组件为 Hook,可以让我们更好地复用组件逻辑并在函数组件中使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值