ReactJS 教程

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 事件 ReactJS - 状态管理 ReactJS - 状态管理 API ReactJS - 无状态组件 ReactJS - Hooks 进行状态管理 ReactJS - Hooks 的组件生命周期 ReactJS - 布局组件 ReactJS - 分页 ReactJS - Material UI ReactJS - Http 客户端编程 ReactJS - 表单编程 ReactJS - 受控组件 ReactJS - 非受控组件 ReactJS - Formik ReactJS - 条件渲染 ReactJS - 列表 ReactJS - Key 键 ReactJS - 路由 ReactJS - Redux ReactJS - 动画 ReactJS - Bootstrap ReactJS - Map ReactJS - 表格 ReactJS - 使用 Flux 管理状态 ReactJS - 测试 ReactJS - CLI 命令 ReactJS - 构建和部署 ReactJS - 示例

Hooks

ReactJS - Hooks 简介 ReactJS - 使用 useState ReactJS - 使用 useEffect ReactJS - 使用 useContext ReactJS - 使用 useRef ReactJS - 使用 useReducer ReactJS - 使用 useCallback ReactJS - 使用 useMemo ReactJS - 自定义 Hooks

ReactJS 高级

ReactJS - 可访问性 ReactJS - 代码拆分 ReactJS - 上下文 ReactJS - 错误边界 ReactJS - 转发 Refs ReactJS - 片段 ReactJS - 高阶组件 ReactJS - 与其他库集成 ReactJS - 优化性能 ReactJS - Profiler API ReactJS - Portals ReactJS - 不使用 ES6 ECMAScript ReactJS - 不使用 JSX 的 React ReactJS - Reconciliation ReactJS - Refs 和 DOM ReactJS - 渲染道具 ReactJS - 静态类型检查 ReactJS - 严格模式 ReactJS - Web 组件

其他概念

ReactJS - 日期选择器 ReactJS - Helmet ReactJS - 内联样式 ReactJS - PropTypes ReactJS - BrowserRouter ReactJS - DOM ReactJS - 轮播 ReactJS - 图标 ReactJS - 表单组件 ReactJS - 参考 API

ReactJS 有用资源

ReactJS - 快速指南 ReactJS - 备忘录 Axios - 备忘录 ReactJS - 有用资源 ReactJS - 讨论


ReactJS - createRef() 函数

createRef() 是用于管理和与应用程序中的项目交互的 React 工具。它通常用于类组件,但我们也将讨论其等效函数 useRef(),它通常用于函数组件。

它类似于可以容纳项目数组的容器。它在 React 中用于在类组件内创建引用对象。此引用对象具有一个名为 current 的属性,可以调整为各种值。

语法

class MyClass extends Component {
   classRef = createRef();
   // ...
}

在此示例中,classRef 是对某个对象的引用,我们可以使用它与组件中的某个对象进行交互。

参数

createRef() 不接受任何参数。

返回值

当我们调用它时,它会返回一个对象,其中当前属性默认设置为 null。此属性稍后可以更改为引用组件中的不同元素。

示例

示例 1

import React, { createRef, Component } from 'react';
import './App.css';

class App extends Component {
   inputRef = createRef();   
   componentDidMount() {
      this.inputRef.current.focus();
   }
   
   render() {
      return <div className='App'><input ref={this.inputRef} />
      </div>
   }
}

export default App;

输出

hello text

当我们启动程序时,输入光标会立即放在一个框内,以便我们开始输入。这在我们希望用户拥有流畅且专注的输入体验的情况下非常有用,例如在线表单或搜索栏。

示例 2

在此应用中,我们设置了一个每秒滴答一次的计时器。它可用于显示已过去的时间或定期启动事件。计时器在应用加载时开始,在应用关闭时结束。

import React, { createRef, Component } from 'react';
import './App.css';

class TimerComponent extends Component {
   timerRef = createRef();   
   componentDidMount() {
      this.timerRef.current = setInterval(() => {
         console.log('Timer tick');
      }, 1000);
   }
   
   componentWillUnmount() {
      clearInterval(this.timerRef.current);
   }   
   render() {
      return <div>Timer Component</div>;
   }
}

export default TimerComponent;

输出

timer component

此应用程序用于管理时间敏感型任务。启动应用程序时,计时器开始每秒计时。当我们需要计时或定期触发某些事件时,计时器会非常方便。退出应用程序时,计时器会停止。

示例 3

单击此应用程序中的按钮时,框的颜色会变为浅蓝色。它展示了如何使用 React 轻松地与我们网站上的项目进行交互并更改其外观。这对于创建交互式动态用户界面非常有用。

import React, { createRef, Component } from 'react';

class App extends Component {
   divRef = createRef();   
   handleClick = () => {
      this.divRef.current.style.backgroundColor = 'lightblue';
   };
   
   render() {
      return <div ref={this.divRef} onClick={this.handleClick}><h1>Click me!</h1></div>;
   }
}

export default App;

输出

click me reactapp

运行应用程序后,我们可以快速与网页元素进行交互。单击按钮时,框的颜色变为浅蓝色。此示例展示了 React 如何让我们轻松调整和控制网页上项目的外观。

限制

值得注意的是,每次调用 createRef() 时,我们都会得到一个新对象。这意味着如果我们比较两个 ref,即使它们是通过 createRef() 创建的,它们也是不同的对象。这对于类组件来说很棒,但在函数组件中,我们可以选择 useRef(),它总是返回相同的对象。

总结

createRef() 是 React 中的一个有用函数,特别是对于类组件。它允许我们轻松地引用和与元素交互。在函数组件中,我们可能需要考虑对同一个引用对象使用 useRef()。

reactjs_reference_api.html