[React Typescript 2022] Type a Radio Button Component in React using TypeScript

Our Radiocomponent file contains several compound components to create a related group of radio inputs. The RadioGroupContext is receiving a type of any currently.

This is a great example to peer into how Strict mode works. To see the difference between the strict mode's true and false setting, we will set strict to true. This will change our RadioGroupContext to be of type null which will raise some issues later down the line where trying to destructure an object that might be null.

This also gives us the opportunity to better our application with error handling. I will write out a couple of custom hooks to help out with that.

interface RadioGroupContentValue {
    checked: string | null | undefined;
    onChange(value: string): void;
    name: String;
}
复制代码
const RadioGroupContext = React.createContext<RadioGroupContentValue | null>(
    null
);

...

let { checked, onChange, name } = useRadioGroupContent("RadioGroup");
...
function useRadioGroupContent(name: string) {
    let ctx = React.useContext(RadioGroupContext);
    if (!ctx) {
        throw Error(`A ${name} was rendered outside a RadioGroup Component`);
    }

    return ctx;
}
复制代码

 

posted @   Zhentiw  阅读(66)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-12-30 [Java] Primitive Stream
2020-12-30 [Java] Stream Intro example
2020-12-30 [Java] Collections Intro example
2018-12-30 [PWA] Disable Text Selection and Touch Callouts in a PWA on iOS
2018-12-30 [PWA] Customize the Splash Screen of a PWA built with create-react-app
2018-12-30 [PWA] Show an Error when a POST or DELETE Fails in an Offline PWA
2015-12-30 [Javascript] Array methods in depth - indexOf
点击右上角即可分享
微信分享提示