React 参考手册

简介: 10月更文挑战第13天

React 手册包含了各种核心 API、Hooks、组件生命周期方法等。

以下是一些常见的函数和方法,以及它们的简要说明:

React 核心 API

createElement(type, [props], [...children]) - 创建一个 React 元素或组件。

实例

import React from 'react';


const element = React.createElement('div', { className: 'container' }, 'Hello, World!');

// React.createElement 返回一个 React 元素

cloneElement(element, [props], [...children]) - 克隆并返回一个 React 元素,可以传递新的 props 和子元素。

实例

import React, { cloneElement } from 'react';


const parentElement = <div>Hello</div>;

const clonedElement = cloneElement(parentElement, { className: 'child' });

// clonedElement 是一个克隆的 React 元素,带有新的 className

createFactory(type) - 创建一个工厂函数,用于创建指定类型的 React 元素。

实例

import React from 'react';


const factory = React.createFactory('button');

const buttonElement = factory({ onClick: () => console.log('Button clicked') }, 'Click me');

// buttonElement 是一个工厂创建的 React 元素,一个可点击的按钮

isValidElement(element) - 判断一个对象是否是有效的 React 元素。

实例

import React, { isValidElement } from 'react';


const element = <div>Hello</div>;

console.log(isValidElement(element)); // true

Children.map(children, function[(thisArg)]) - 遍历和映射 React 子元素。

实例

import React, { Children } from 'react';


const parentElement = (

 <ul>

   <li>Item 1</li>

   <li>Item 2</li>

   <li>Item 3</li>

 </ul>

);


const mappedChildren = Children.map(parentElement.props.children, child => (

 <li>{child}</li>

));

// mappedChildren 是映射后的子元素列表

React 组件生命周期方法

constructor(props) - 构造函数,在组件创建时调用,用于初始化 state 和绑定方法。

实例

import React, { Component } from 'react';


class MyComponent extends Component {

 constructor(props) {

   super(props);

   this.state = {

     count: 0

   };

 }


 render() {

   return <div>{this.state.count}</div>;

 }

}

componentDidMount() - 组件挂载后调用,通常用于数据获取、订阅等副作用操作。

实例

import React, { Component } from 'react';


class MyComponent extends Component {

 componentDidMount() {

   // 在组件挂载后订阅数据

   this.subscription = subscribeToData(data => {

     this.setState({ data });

   });

 }


 componentWillUnmount() {

   // 在组件卸载前取消订阅

   this.subscription.unsubscribe();

 }


 render() {

   return <div>{this.state.data}</div>;

 }

}

componentDidUpdate(prevProps, prevState) - 组件更新后调用,通常用于响应 props 或 state 的变化。

实例

import React, { Component } from 'react';


class MyComponent extends Component {

 componentDidUpdate(prevProps, prevState) {

   // 当 props 或 state 变化时更新数据

   if (this.props.userID !== prevProps.userID) {

     this.fetchData(this.props.userID);

   }

 }


 render() {

   return <div>{this.props.userID}</div>;

 }

}

componentWillUnmount() - 组件将被卸载前调用,用于清理定时器、取消订阅等资源释放。

实例

import React, { Component } from 'react';


class MyComponent extends Component {

 componentWillUnmount() {

   // 在组件卸载前清理资源

   clearInterval(this.timerID);

 }


 render() {

   return <div>{this.state.time}</div>;

 }

}

static getDerivedStateFromProps(props, state) - 用于替代 componentWillReceiveProps,在 props 变化时更新 state。

实例

import React, { Component } from 'react';


class MyComponent extends Component {

 static getDerivedStateFromProps(nextProps, prevState) {

   if (nextProps.userID !== prevState.userID) {

     return { userID: nextProps.userID };

   }

   return null;

 }


 render() {

   return <div>{this.state.userID}</div>;

 }

}

React Hooks

useState(initialState) - 声明一个状态变量及其更新函数。

实例

import React, { useState } from 'react';


function Counter() {

 const [count, setCount] = useState(0);


 return (

   <div>

     <p>You clicked {count} times</p>

     <button onClick={() => setCount(count + 1)}>Click me</button>

   </div>

 );

}

useEffect(callback, [dependencies]) - 声明一个副作用操作,类似于 componentDidMount 和 componentDidUpdate 的组合。

实例

import React, { useState, useEffect } from 'react';


function Timer() {

 const [seconds, setSeconds] = useState(0);


 useEffect(() => {

   const interval = setInterval(() => {

     setSeconds(seconds => seconds + 1);

   }, 1000);


   return () => clearInterval(interval);

 }, []); // 空数组作为第二个参数表示仅在组件挂载和卸载时执行


 return <p>Timer: {seconds} seconds</p>;

}

useContext(context) - 获取并订阅一个 React context。

实例

import React, { useContext } from 'react';


const MyContext = React.createContext('default');


function MyComponent() {

 const contextValue = useContext(MyContext);

 return <p>Context value: {contextValue}</p>;

}

useReducer(reducer, initialState) - 声明一个复杂状态逻辑的 reducer 和 dispatch 函数。

实例

import React, { useReducer } from 'react';


const initialState = { count: 0 };


function reducer(state, action) {

 switch (action.type) {

   case 'increment':

     return { count: state.count + 1 };

   case 'decrement':

     return { count: state.count - 1 };

   default:

     throw new Error();

 }

}


function Counter() {

 const [state, dispatch] = useReducer(reducer, initialState);


 return (

   <div>

     <p>Count: {state.count}</p>

     <button onClick={() => dispatch({ type: 'increment' })}>Increment</button>

     <button onClick={() => dispatch({ type: 'decrement' })}>Decrement</button>

   </div>

 );

}

useCallback(callback, [dependencies]) - 缓存一个回调函数,以便在依赖项变化时避免重复创建。

实例

import React, { useState, useCallback } from 'react';


function ParentComponent() {

 const [count, setCount] = useState(0);


 const increment = useCallback(() => {

   setCount(count + 1);

 }, [count]);


 return (

   <div>

     <ChildComponent onClick={increment} />

   </div>

 );

}


function ChildComponent({ onClick }) {

 return <button onClick={onClick}>Increment Count</button>;

}

useMemo(factory, [dependencies]) - 缓存计算值,以便在依赖项变化时避免重复计算。

实例

import React, { useMemo } from 'react';


function ExpensiveComponent({ data }) {

 const expensiveValue = useMemo(() => {

   return computeExpensiveValue(data);

 }, [data]);


 return <div>Expensive value: {expensiveValue}</div>;

}

useRef(initialValue) - 创建一个持久化的引用,可用于访问 DOM 元素或缓存任何可变值。

实例

import React, { useRef, useEffect } from 'react';


function TextInputWithFocusButton() {

 const inputRef = useRef(null);


 useEffect(() => {

   inputRef.current.focus();

 }, []);


 return (

   <>

     <input ref={inputRef} type="text" />

     <button onClick={() => inputRef.current.focus()}>Focus Input</button>

   </>

 );

}

其他常见函数

ReactDOM.render(element, container[, callback]) - 将 React 元素渲染到指定的 DOM 节点。

实例

import React from 'react';

import ReactDOM from 'react-dom';


const element = <h1>Hello, World!</h1>;

ReactDOM.render(element, document.getElementById('root'));

ReactDOM.createRoot(container[, options]) - 创建一个 React 根实例,支持并发渲染特性。

实例

import ReactDOM from 'react-dom';


const root = ReactDOM.createRoot(document.getElementById('root'));

root.render(<App />);

ReactDOM.unmountComponentAtNode(container) - 卸载指定 DOM 节点上的 React 组件。

实例

import React from 'react';

import ReactDOM from 'react-dom';


ReactDOM.unmountComponentAtNode(document.getElementById('root'));

ReactDOMServer.renderToString(element) - 将 React 元素渲染为静态 HTML 字符串,用于服务器端渲染。

实例

import React from 'react';

import ReactDOMServer from 'react-dom/server';


const element = <div>Hello, World!</div>;

const htmlString = ReactDOMServer.renderToString(element);

目录
相关文章
|
6月前
|
前端开发
React官网 - 井字棋 - 游戏改进参考答案(含汉化和完整范例代码)
React官网 - 井字棋 - 游戏改进参考答案(含汉化和完整范例代码)
51 1
|
前端开发 JavaScript
react开发规范参考
react开发规范参考
216 0
|
JavaScript 前端开发 中间件
【react入门手册】学习react-redux,看这篇文章就够啦!
【react入门手册】学习react-redux,看这篇文章就够啦!
134 0
|
前端开发 JavaScript
【react入门手册】react 函数组件中 props应用
【react入门手册】react 函数组件中 props应用
151 0
|
前端开发 JavaScript API
【react入门手册】react 基础操作-语法、特性 、路由配置
【react入门手册】react 基础操作-语法、特性 、路由配置
179 0
|
前端开发 JavaScript
【React工作记录三十六】react开发规范参考
【React工作记录三十六】react开发规范参考
230 0
|
前端开发 JavaScript
#yyds干货盘点 【React工作记录三十六】react开发规范参考
#yyds干货盘点 【React工作记录三十六】react开发规范参考
97 0
|
前端开发 JavaScript
#yyds干货盘点# 【React工作记录三十六】react开发规范参考
#yyds干货盘点# 【React工作记录三十六】react开发规范参考
167 0
#yyds干货盘点# 【React工作记录三十六】react开发规范参考
|
JavaScript 前端开发
React and Redux 手册
redux-cheat-sheet-3-2-1.pdf react-cheat-sheet-0-14-7.pdf
1266 0
|
2月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
89 9