zoukankan      html  css  js  c++  java
  • [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;
    }
  • 相关阅读:
    多态实现--虚函数与纯虚函数
    CentOS6编译安装gcc高版本
    Linux多进程CS服务器简单测试
    Linux单用户CS模型TCP通讯完全注释手册
    进程线程及其状态
    Java学习-字符串、字符、ASCII、数字的互相转换
    Java学习-素数
    Java学习-日期
    Java学习-多态
    Java学习-练习
  • 原文地址:https://www.cnblogs.com/Answer1215/p/15750747.html
Copyright © 2011-2022 走看看