V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Danswerme
V2EX  ›  问与答

请教各位在 TS 中怎样对一个联合类型进行类型收窄呢?

  •  
  •   Danswerme · 2023-05-12 20:25:03 +08:00 · 662 次点击
    这是一个创建于 555 天前的主题,其中的信息可能已经有所发展或是发生改变。

    React 组件的 Props 接收一个 config 数组,config 数组里面是 React 组件或者自定义配置;如果是 React 组件则直接渲染,否则按照配置项进行渲染。

    目前我是通过typeof来判断Item的类型,请教各位有没有更优雅的方法呢?

    代码如下:

    interface ItemConfig {
        name: string,
        type: string
    }
    
    type Config = ItemConfig | React.FC;
    
    interface XProps {
    	config: Config[]
    }
    
    const Components = ({ config } : XProps) => {
        return (
            <div>
                {
                    config.map(Item => {
                        if (typeof Item === "function") {
                            if (React.isValidElement(Item)) {
                                // 如果是 React 组件
                                return <Item />;
                            }
    
                            return null;
                        }
                        
                        // 如果是自定义配置
                        
                        ...
                        
                        return ...
                    })
                }
            </div>
        );
    }
    
    
    3 条回复    2023-05-12 22:52:45 +08:00
    leokun
        1
    leokun  
       2023-05-12 22:05:48 +08:00
    我感觉你做的和我一样,我感觉没什么毛病,ts 不能在运行时检查,只能通过 js 的 typeof 来推断
    XCFOX
        2
    XCFOX  
       2023-05-12 22:16:10 +08:00
    Danswerme
        3
    Danswerme  
    OP
       2023-05-12 22:52:45 +08:00
    @leokun
    @XCFOX 谢谢!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5591 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 05:53 · PVG 13:53 · LAX 21:53 · JFK 00:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.