[d565449] | 1 | # `react-is`
|
---|
| 2 |
|
---|
| 3 | This package allows you to test arbitrary values and see if they're a particular React element type.
|
---|
| 4 |
|
---|
| 5 | ## Installation
|
---|
| 6 |
|
---|
| 7 | ```sh
|
---|
| 8 | # Yarn
|
---|
| 9 | yarn add react-is
|
---|
| 10 |
|
---|
| 11 | # NPM
|
---|
| 12 | npm install react-is
|
---|
| 13 | ```
|
---|
| 14 |
|
---|
| 15 | ## Usage
|
---|
| 16 |
|
---|
| 17 | ### Determining if a Component is Valid
|
---|
| 18 |
|
---|
| 19 | ```js
|
---|
| 20 | import React from "react";
|
---|
| 21 | import * as ReactIs from "react-is";
|
---|
| 22 |
|
---|
| 23 | class ClassComponent extends React.Component {
|
---|
| 24 | render() {
|
---|
| 25 | return React.createElement("div");
|
---|
| 26 | }
|
---|
| 27 | }
|
---|
| 28 |
|
---|
| 29 | const FunctionComponent = () => React.createElement("div");
|
---|
| 30 |
|
---|
| 31 | const ForwardRefComponent = React.forwardRef((props, ref) =>
|
---|
| 32 | React.createElement(Component, { forwardedRef: ref, ...props })
|
---|
| 33 | );
|
---|
| 34 |
|
---|
| 35 | const Context = React.createContext(false);
|
---|
| 36 |
|
---|
| 37 | ReactIs.isValidElementType("div"); // true
|
---|
| 38 | ReactIs.isValidElementType(ClassComponent); // true
|
---|
| 39 | ReactIs.isValidElementType(FunctionComponent); // true
|
---|
| 40 | ReactIs.isValidElementType(ForwardRefComponent); // true
|
---|
| 41 | ReactIs.isValidElementType(Context.Provider); // true
|
---|
| 42 | ReactIs.isValidElementType(Context.Consumer); // true
|
---|
| 43 | ReactIs.isValidElementType(React.createFactory("div")); // true
|
---|
| 44 | ```
|
---|
| 45 |
|
---|
| 46 | ### Determining an Element's Type
|
---|
| 47 |
|
---|
| 48 | #### Context
|
---|
| 49 |
|
---|
| 50 | ```js
|
---|
| 51 | import React from "react";
|
---|
| 52 | import * as ReactIs from 'react-is';
|
---|
| 53 |
|
---|
| 54 | const ThemeContext = React.createContext("blue");
|
---|
| 55 |
|
---|
| 56 | ReactIs.isContextConsumer(<ThemeContext.Consumer />); // true
|
---|
| 57 | ReactIs.isContextProvider(<ThemeContext.Provider />); // true
|
---|
| 58 | ReactIs.typeOf(<ThemeContext.Provider />) === ReactIs.ContextProvider; // true
|
---|
| 59 | ReactIs.typeOf(<ThemeContext.Consumer />) === ReactIs.ContextConsumer; // true
|
---|
| 60 | ```
|
---|
| 61 |
|
---|
| 62 | #### Element
|
---|
| 63 |
|
---|
| 64 | ```js
|
---|
| 65 | import React from "react";
|
---|
| 66 | import * as ReactIs from 'react-is';
|
---|
| 67 |
|
---|
| 68 | ReactIs.isElement(<div />); // true
|
---|
| 69 | ReactIs.typeOf(<div />) === ReactIs.Element; // true
|
---|
| 70 | ```
|
---|
| 71 |
|
---|
| 72 | #### Fragment
|
---|
| 73 |
|
---|
| 74 | ```js
|
---|
| 75 | import React from "react";
|
---|
| 76 | import * as ReactIs from 'react-is';
|
---|
| 77 |
|
---|
| 78 | ReactIs.isFragment(<></>); // true
|
---|
| 79 | ReactIs.typeOf(<></>) === ReactIs.Fragment; // true
|
---|
| 80 | ```
|
---|
| 81 |
|
---|
| 82 | #### Portal
|
---|
| 83 |
|
---|
| 84 | ```js
|
---|
| 85 | import React from "react";
|
---|
| 86 | import ReactDOM from "react-dom";
|
---|
| 87 | import * as ReactIs from 'react-is';
|
---|
| 88 |
|
---|
| 89 | const div = document.createElement("div");
|
---|
| 90 | const portal = ReactDOM.createPortal(<div />, div);
|
---|
| 91 |
|
---|
| 92 | ReactIs.isPortal(portal); // true
|
---|
| 93 | ReactIs.typeOf(portal) === ReactIs.Portal; // true
|
---|
| 94 | ```
|
---|
| 95 |
|
---|
| 96 | #### StrictMode
|
---|
| 97 |
|
---|
| 98 | ```js
|
---|
| 99 | import React from "react";
|
---|
| 100 | import * as ReactIs from 'react-is';
|
---|
| 101 |
|
---|
| 102 | ReactIs.isStrictMode(<React.StrictMode />); // true
|
---|
| 103 | ReactIs.typeOf(<React.StrictMode />) === ReactIs.StrictMode; // true
|
---|
| 104 | ```
|
---|