首页 > 其他分享 >[React Typescript] React namespace

[React Typescript] React namespace

时间:2023-08-21 15:11:20浏览次数:43  
标签:Typescript ReactNode namespace React export import type

export = React;
export as namespace React;

declare namespace React {
    //
    // React Elements
    // ----------------------------------------------------------------------

    type ElementType<P = any> =
        {
            [K in keyof JSX.IntrinsicElements]: P extends JSX.IntrinsicElements[K] ? K : never
        }[keyof JSX.IntrinsicElements] |
        ComponentType<P>;
    
    ...
    // DOM Elements
    function createFactory<T extends HTMLElement>(
        type: keyof ReactHTML): HTMLFactory<T>;
    ...
}

 

So what does export = Reactdo?

// Usage
import React from "react"
type Example = React.ReactNode;

// or
import {ReactNode} from "react"
type Example = ReactNode;

Basicly it allows us to export the entrie React namespace, by using as import React from "react", or we can just destruct individual element from namespace import {ReactNode} from "react"

 

what does export as namespace React;do?

So in any ts file, you can use Reactwithout import:

type Example = React.ReactNode

If we comment out export as namespace React;then Reactnamespace is not availbe;

标签:Typescript,ReactNode,namespace,React,export,import,type
From: https://www.cnblogs.com/Answer1215/p/17646072.html

相关文章