[React Typescript] Overriding and Removing Component Props

Using Omit

import { ComponentProps } from 'react';
import { Equal, Expect } from '../helpers/type-utils';

export const Input = (
  props: Omit<ComponentProps<'input'>, 'onChange'> & {
    onChange: (value: string) => void;
  }
) => {
  return (
    <input
      {...props}
      onChange={(e) => {
        props.onChange(e.target.value);
      }}
    ></input>
  );
};

const Parent = () => {
  return (
    <Input
      onChange={(e) => {
        console.log(e);

        type test = Expect<Equal<typeof e, string>>;
      }}
    ></Input>
  );
};

 

Better

import { ComponentProps } from 'react';
import { Equal, Expect } from '../helpers/type-utils';

type InputProps = Omit<ComponentProps<'input'>, 'onChange'> & {
    onChange: (value: string) => void;
  }

export const Input = (
  props: InputProps
) => {
  return (
    <input
      {...props}
      onChange={(e) => {
        props.onChange(e.target.value);
      }}
    ></input>
  );
};

const Parent = () => {
  return (
    <Input
      onChange={(e) => {
        console.log(e);

        type test = Expect<Equal<typeof e, string>>;
      }}
    ></Input>
  );
};

 

Even Better:

type OverrideProps<T, TOverriden> = Omit<T, keyof TOverridden> & TOverridden;

type InputProps = OverrideProps<ComponentProps<"input">, {onChange: (value: string) => void}>

 

Using interface:

interface InputProps extends Omit<ComponentProps<"input">, "onChange"> {
  onChange: (value: string) => void;
}

 

posted @   Zhentiw  阅读(35)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2017-05-22 [Http] Understand what an HTTP Request is
2016-05-22 [io PWA] keynote: Launching a Progressive Web App on Google.com
2016-05-22 [PWA] 18. Clean the photo cache
2016-05-22 [PWA] 17. Cache the photo
点击右上角即可分享
微信分享提示