react is
该软件包允许测试任意值,看看他们是否属于特定的 React 元素类型。
一、 使用示例
1. 判定组件是否是有效
import React from 'react';
import * as ReactIs from 'react-is';
class ClassComponent extends React.Component {
render() {
return React.createElement('div');
}
}
const FunctionComponent = () => React.createElement('div');
const ForwardRefComponent = React.forwardRef((props, ref) =>
React.createElement(Component, { forwardedRef: ref, ...props }),
);
const Context = React.createContext(false);
ReactIs.isValidElementType('div'); // true
ReactIs.isValidElementType(ClassComponent); // true
ReactIs.isValidElementType(FunctionComponent); // true
ReactIs.isValidElementType(ForwardRefComponent); // true
ReactIs.isValidElementType(Context.Provider); // true
ReactIs.isValidElementType(Context.Consumer); // true
2. 确定元素的上下文类型
import React from 'react';
import * as ReactIs from 'react-is';
const ThemeContext = React.createContext('blue');
ReactIs.isContextConsumer(<ThemeContext.Consumer />); // true
ReactIs.isContextProvider(<ThemeContext.Provider />); // true
ReactIs.typeOf(<ThemeContext.Provider />) === ReactIs.ContextProvider; // true
ReactIs.typeOf(<ThemeContext.Consumer />) === ReactIs.ContextConsumer; // true
3. 判定是否为 JSX 元素
import React from 'react';
import * as ReactIs from 'react-is';
ReactIs.isElement(<div />); // true
ReactIs.typeOf(<div />) === ReactIs.Element; // true
4. 判定是否是 JSX 片段
import React from 'react';
import * as ReactIs from 'react-is';
ReactIs.isFragment(<></>); // true
ReactIs.typeOf(<></>) === ReactIs.Fragment; // true
5. 判定是否是使用 React.createPortal 构建的 JSX
import React from 'react';
import ReactDOM from 'react-dom';
import * as ReactIs from 'react-is';
const div = document.createElement('div');
const portal = ReactDOM.createPortal(<div />, div);
ReactIs.isPortal(portal); // true
ReactIs.typeOf(portal) === ReactIs.Portal; // true
6. 判定是否为严格模式
import React from 'react';
import * as ReactIs from 'react-is';
ReactIs.isStrictMode(<React.StrictMode />); // true
ReactIs.typeOf(<React.StrictMode />) === ReactIs.StrictMode; // true