- ReactJS 菜鸟教程
- ReactJS 教程
- ReactJS - 简介
- ReactJS - 安装
- ReactJS - 特性
- ReactJS - 优点和缺点
- ReactJS - 架构
- ReactJS - 创建 React 应用程序
- ReactJS - JSX
- ReactJS - 组件
- ReactJS - 嵌套组件
- ReactJS - 使用组件
- ReactJS - 组件集合
- ReactJS - 样式
- ReactJS - 属性(props)
- ReactJS - 使用属性创建组件
- ReactJS - props 验证
- ReactJS - 构造函数
- ReactJS - 组件生命周期
- ReactJS - 事件管理
- ReactJS - 创建事件感知组件
- ReactJS - 在Expense Manager APP中引入事件
- ReactJS - 状态管理
- ReactJS - 状态管理 API
- ReactJS - 无状态组件
- ReactJS - 使用 React Hooks 进行状态管理
- ReactJS - 使用 React 钩子的组件生命周期
- ReactJS - 组件的布局
- ReactJS - 分页
- ReactJS - Material 用户界面
- ReactJS - Http 客户端编程
- ReactJS - 表单编程
- ReactJS - 受控组件
- ReactJS - 不受控制的组件
- ReactJS - Formik
- ReactJS - 条件渲染
- ReactJS - 列表
- ReactJS - 键
- ReactJS - 路由
- ReactJS - 冗余
- ReactJS - 动画
- ReactJS - 引导程序
- ReactJS - 地图
- ReactJS - 表格
- ReactJS - 使用 Flux 管理状态
- ReactJS - 测试
- ReactJS - CLI 命令
- ReactJS - 构建和部署
- ReactJS - 示例
- ReactJS - 钩子简介
- ReactJS - 使用 useState
- ReactJS - 使用 useEffect
- ReactJS - 使用 useContext
- ReactJS - 使用 useRef
- ReactJS - 使用 useReducer
- ReactJS - 使用 useCallback
- ReactJS - 使用 useMemo
- ReactJS - 自定义钩子
- ReactJS - 可访问性
- ReactJS - 代码拆分
- ReactJS - 上下文
- ReactJS - 错误边界
- ReactJS - 转发引用
- ReactJS - 片段
- ReactJS - 高阶组件
- ReactJS - 与其他库集成
- ReactJS - 优化性能
- ReactJS - 分析器 API
- ReactJS - 门户
- ReactJS - 没有 ES6 ECMAScript 的 React
- ReactJS - 没有 JSX 的 React
- ReactJS - 协调
- ReactJS - 引用和 DOM
- ReactJS - 渲染属性
- ReactJS - 静态类型检查
- ReactJS - 严格模式
- ReactJS - Web 组件
- ReactJS - 日期选择器
- ReactJS - Helmet
- ReactJS - 内联样式
- ReactJS - 属性类型
- ReactJS - 浏览器路由器
- ReactJS - DOM
- ReactJS - 旋转木马
- ReactJS - 图标
- ReactJS - 表单组件
- ReactJS - 参考 API
ReactJS - 转发引用
Ref 是一个逃生舱口,用于直接操作 DOM,而不会影响状态更改更新组件。Ref 可以应用于 DOM 元素,但要将 Ref 应用于 React 组件并将 DOM 元素深入组件内部,可以选择 Forwarding Ref。转发 Ref 让组件从顶级组件接收 ref,并将其进一步向下传递到下一级组件,以获取 DOM 元素。
在本章中,让我们学习如何使用 Forwarding ref。
forwardRef 方法的签名
forwardRef的签名如下:
const new-component = React.forwardRef(fn)
其中 fn 的签名如下 :
(props, ref) => {
// renders a react component by attaching the ref and returns it
}
使用 forwardRef 的简单示例如下:
const MyInput = React.forwardRef((props, ref) => (
<input type="text" ref={ref} value={props.value} />
));
const myRef = React.createRef();
<MyInput ref={myRef} value="Hi" />
这里
- MyInput 从顶层获取 ref,并将其传递给底层输入元素。
- myRef 被分配给 MyInput 组件。
- MyInput 组件将 myRef 传递给底层输入元素。
- 最后,myRef 指向输入元素。
在组件中应用 forwardRef
让我们通过开发一个应用程序来学习 forwardRef 的概念。
首先,创建一个新的 react 应用程序并使用以下命令启动它。
create-react-app myapp
cd myapp
npm start
cd myapp
npm start
接下来,打开 App.css (src/App.css) 并删除所有 CSS 类。然后,创建一个简单的组件 SimpleForwardRef (src/Components/SimpleForwardRef.js),如下所示 -
import React from "react";
const SimpleForwardRef = React.forwardRef((props, ref) => (
<input type="text" ref={ref} value={props.value} />
));
export default SimpleForwardRef
在这里,我们有,
- 使用 forwardRef 将 ref 传递给输入元素。
- input 元素使用 ref props 来设置 ref 值。
接下来,打开 App 组件 (src/App.js) 并使用 SimpleForwardRef 组件更新内容,如下所示 -
import './App.css'
import React, { useEffect } from 'react';
import SimpleForwardRef from './Components/SimpleForwardRef'
function App() {
const myRef = React.createRef();
useEffect(() => {
setTimeout(() => {
myRef.current.value = "Hello"
}, 5000)
})
return (
<div className="container">
<div style={{ padding: "10px" }}>
<div>
<SimpleForwardRef ref={myRef} value="Hi" />
</div>
</div>
</div>
);
}
export default App;
这里
- myRef 是使用 createRef 方法创建的,并将其传递给 SimpleForwardRef 组件。
- myRef 表示由 SimpleForwardRef 组件呈现的输入元素。
- useEffect 将通过 myRef 访问输入元素,并尝试将 input 的值从 hi 更改为 Hello。
最后,在浏览器中打开应用程序。输入的值将在 5 秒后更改为 Hello,如下所示 -
总结
Forward ref 增强了 ref 概念,可以在 react 应用程序中的任何地方使用。任何 DOM 元素,可能是组件层次结构中的任何级别,都可以使用转发 ref 概念来访问和操作。