我的编程空间,编程开发者的网络收藏夹
学习永远不晚

react中如何设置focus

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

react中如何设置focus

这篇文章主要介绍了react中如何设置focus的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react中如何设置focus文章都会有所收获,下面我们一起来看看吧。

react中设置focus的方法:1、在componentDidMount中使用DOM元素;2、调用“this.input.focus()”的 DOM API即可使整体达到页面加载完成就自动focus到输入框的功能。

React 进入页面以后自动 focus 到某个输入框

react中如何设置focus

在 React.js 当中你基本不需要和 DOM 直接打交道。React.js 提供了一系列的 on* 方法帮助我们进行事件监听,所以 React.js 当中不需要直接调用 addEventListener 的 DOM API;以前我们通过手动 DOM 操作进行页面更新(例如借助 jQuery),而在 React.js 当中可以直接通过 setState 的方式重新渲染组件,渲染的时候可以把新的 props 传递给子组件,从而达到页面更新的效果。

React.js 这种重新渲染的机制帮助我们免除了绝大部分的 DOM 更新操作,也让类似于 jQuery 这种以封装 DOM 操作为主的第三方的库从我们的开发工具链中删除。

但是 React.js 并不能完全满足所有 DOM 操作需求,有些时候我们还是需要和 DOM 打交道。比如说你想进入页面以后自动 focus 到某个输入框,你需要调用 input.focus() 的 DOM API,比如说你想动态获取某个 DOM 元素的尺寸来做后续的动画,等等。

React.js 当中提供了 ref 属性来帮助我们获取已经挂载的元素的 DOM 节点,你可以给某个 JSX 元素加上 ref属性。

可以看到我们给 input 元素加了一个 ref 属性,这个属性值是一个函数。当 input 元素在页面上挂载完成以后,React.js 就会调用这个函数,并且把这个挂载以后的 DOM 节点传给这个函数。在函数中我们把这个 DOM 元素设置为组件实例的一个属性,这样以后我们就可以通过 this.input 获取到这个 DOM 元素。

然后我们就可以在 componentDidMount 中使用这个 DOM 元素,并且调用 this.input.focus() 的 DOM API。整体就达到了页面加载完成就自动 focus 到输入框的功能(大家可以注意到我们用上了 componentDidMount 这个组件生命周期)。

我们可以给任意代表 HTML 元素标签加上 ref 从而获取到它 DOM 元素然后调用 DOM API。但是记住一个原则:能不用 ref 就不用。特别是要避免用 ref 来做 React.js 本来就可以帮助你做到的页面自动更新的操作和事件监听。多余的 DOM 操作其实是代码里面的“噪音”,不利于我们理解和维护。

<!DOCTYPE html><html><head><meta charset="UTF-8" /><title>React 进入页面以后自动 focus 到某个输入框</title><script class="lazy" data-src="https://unpkg.com/react@16/umd/react.development.js"></script><script class="lazy" data-src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script><script class="lazy" data-src="https://unpkg.com/babel-standalone@6.15.0/babel.min.js"></script></head><body><div id="root"></div><script type="text/babel">class AutoFocusInput extends React.Component {  componentDidMount () {    this.input.focus()  }   render () {    return (      <input ref={(input) => this.input = input} />    )  }}ReactDOM.render(  <AutoFocusInput />,  document.getElementById('root'));</script></body></html>

另一种写法:

<!DOCTYPE html><html><head><meta charset="UTF-8" /><title>React 进入页面以后自动 focus 到某个输入框</title><script class="lazy" data-src="https://unpkg.com/react@16/umd/react.development.js"></script><script class="lazy" data-src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script><script class="lazy" data-src="https://unpkg.com/babel-standalone@6.15.0/babel.min.js"></script></head><body><div id="root"></div><script type="text/babel">class MyComponent extends React.Component {  constructor(props) {    super(props);     this.inputRef = React.createRef();  }   render() {    return <input type="text" ref={this.inputRef} />;  }   componentDidMount() {    this.inputRef.current.focus();  }}  ReactDOM.render(  <MyComponent />,  document.getElementById('root'));</script></body></html>

关于“react中如何设置focus”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“react中如何设置focus”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

react中如何设置focus

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

react中如何设置focus

这篇文章主要介绍了react中如何设置focus的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react中如何设置focus文章都会有所收获,下面我们一起来看看吧。react中设置focus的方法:1、在com
2023-07-04

react中怎么设置focus

react中设置focus的方法:1、在componentDidMount中使用DOM元素;2、调用“this.input.focus()”的 DOM API即可使整体达到页面加载完成就自动focus到输入框的功能。
2023-05-14

css如何为表单元素设置:focus

这篇文章给大家分享的是有关css如何为表单元素设置:focus的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。为表单元素设置:focus有视力的键盘用户依靠焦点来确定键盘事件在页面中的位置。 使表单元素的焦点脱颖而
2023-06-27

React中如何设置多个className

这篇文章主要介绍了React中如何设置多个className问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-17

react如何设置div高度

这篇文章主要介绍“react如何设置div高度”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react如何设置div高度”文章能帮助大家解决问题。react设置div高度的方法:1、通过css方式实
2023-07-04

react如何设置style属性

这篇文章主要讲解了“react如何设置style属性”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react如何设置style属性”吧!react设置style属性的方法:1、通过“
2023-07-05

react native删除线如何设置

今天小编给大家分享一下react native删除线如何设置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。react nat
2023-07-04

react native如何设置页面背景色

这篇文章主要讲解了“react native如何设置页面背景色”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react native如何设置页面背景色”吧!react native设置页面背
2023-07-04

react如何在React html中使用

本篇文章为大家展示了react如何在React html中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。基本使用
2023-06-14

windows中ntfs如何设置

本篇内容主要讲解“windows中ntfs如何设置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“windows中ntfs如何设置”吧!ntfs设置的方法:1、我们先右击需要设置的硬盘,选择“格式
2022-12-02

recuva如何设置中文

这篇文章主要介绍“recuva如何设置中文”,在日常操作中,相信很多人在recuva如何设置中文问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”recuva如何设置中文”的疑惑有所帮助!接下来,请跟着小编一起来
2023-01-04

playnite中文如何设置

这篇文章主要讲解了“playnite中文如何设置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“playnite中文如何设置”吧!playnite设置中文的方法:1、如果是首次打开,那么需要先
2023-07-02

css如何设置居中

这篇文章主要介绍了css如何设置居中,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。css设置居中的方法:1、通过【margin: 0 auto; text-align: ce
2023-06-14

CrystalDiskMark如何设置中文

这篇文章主要讲解了“CrystalDiskMark如何设置中文”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CrystalDiskMark如何设置中文”吧!CrystalDiskMark设置
2023-07-04

crystaldiskinfo如何设置中文

这篇文章主要讲解了“crystaldiskinfo如何设置中文”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“crystaldiskinfo如何设置中文”吧!crystaldiskinfo设置
2023-02-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录