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

React报错之Object is possibly null的问题及解决方法

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

React报错之Object is possibly null的问题及解决方法

类型守卫

使用类型守卫来解决React中useRef钩子“Object is possibly null”的错误。比如说,if (inputRef.current) {} 。一旦null被排除在ref的类型之外,我们就能够访问ref上的属性。

下面是一个错误如何发生的示例。

import {useEffect, useRef} from 'react';

export default function App() {
  const inputRef = useRef<HTMLInputElement>(null);

  useEffect(() => {
    // ⛔️ Object is possibly 'null'.ts(2531)
    inputRef.current.focus();
  }, []);

  return (
    <div>
      <input ref={inputRef} type="text" id="message" />
      <button>Click</button>
    </div>
  );
}

代码片段中的问题是,TypeScript不能确保我们将一个元素或者一个值赋值给ref,所以它的current属性可能为null

为了解决这个错误,在访问ref类型上的属性之前,我们必须使用类型守卫来从其类型中排除null

import {useEffect, useRef} from 'react';

export default function App() {
  const inputRef = useRef<HTMLInputElement>(null);

  useEffect(() => {
    // ?️ ref could be null here
    if (inputRef.current != null) {
      // ?️ TypeScript knows that ref is not null here
      inputRef.current.focus();
    }
  }, []);

  return (
    <div>
      <input ref={inputRef} type="text" id="message" />
      <button>Click</button>
    </div>
  );
}

我们使用简单的if语句作为类型守卫,来确保ref上的current属性不存储null。当程序进入到if代码块中,TypeScript就会知道ref对象上的current属性就不会存储null

确保在useRef钩子上使用泛型,正确的类型声明ref上的current属性。

注意,我们传递了一个泛型来将ref的值类型声明为HTMLInputElement

一些常用的类型有:HTMLInputElement,HTMLButtonElement,HTMLAnchorElement,HTMLImageElement,HTMLTextAreaElement,HTMLSelectElement 等等。

如果你在ref中存储了不同的值,请确保将特定类型传递给useRef钩子的泛型,例如const ref = useRef<{name: string}>(null);

如果ref上的current属性存储了null,我们也可以使用可选链?. 操作符进行短路运算。

import {useEffect, useRef} from 'react';

export default function App() {
  const inputRef = useRef<HTMLInputElement>(null);

  useEffect(() => {
    // ?️ optional chaining (?.)
    inputRef.current?.focus();
  }, []);

  return (
    <div>
      <input ref={inputRef} type="text" id="message" />
      {}
      <button>Click</button>
    </div>
  );
}

如果引用是空值(null或者undefined),可选链?.操作符会进行短路运算,而不会抛出错误。换句话说,如果ref上的current属性存储了null,操作符会短路运算从而返回undefined。而不会在undefined上尝试调用focus方法,导致一个运行时错误。

非空断言

另一种解决方案是使用非空断言!操作符。

import {useEffect, useRef} from 'react';

export default function App() {
  const inputRef = useRef<HTMLInputElement>(null);

  useEffect(() => {
    // ?️ using non-null (!) assertion
    inputRef.current!.focus();
  }, []);

  return (
    <div>
      <input ref={inputRef} type="text" id="message" />
      {}
      <button>Click</button>
    </div>
  );
}

在TypeScript中,感叹号标记被称为非空断言操作符。被用来从类型中移除nullundefined ,而不用进行任何显式的类型检查。

当我们使用非空断言时,基本上我们就是在告诉TS,ref对象上的current属性不会存储null或者undefined

请注意,这种方法不是类型安全的,因为TypeScript不执行任何检查以确保属性不是空的。

总结

造成 "Object is possibly null"的错误是因为useRef()钩子可以传递一个初始值作为参数,而我们传递null作为初始值。该钩子返回一个可变的ref对象,其.current属性被初始化为所传递的参数。

当传递ref prop给一个元素时,比如<input ref={myRef} /> ,React将ref对象的.current属性设置为相应的DOM节点,但TypeScript无法确定我们是否会将ref设置为DOM元素,或在我们的代码中稍后设置其值。

到此这篇关于React报错之Object is possibly null的文章就介绍到这了,更多相关React  Object is possibly null报错内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

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

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

React报错之Object is possibly null的问题及解决方法

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

下载Word文档

猜你喜欢

基于java.lang.IllegalArgumentException异常报错问题及解决方法

java.lang.IllegalArgumentException是Java中的一个异常类,表示方法的参数不合法。当方法的参数不满足方法定义的要求时,就会抛出该异常。下面是一些可能导致该异常的情况以及解决方法:1. 参数为空:如果方法要求
2023-08-15

superset导出乱码及导出报错问题的解决方法

导出乱码问题的解决方法:1. 检查字符编码:确保导出的文件使用的字符编码与当前系统中使用的字符编码一致。可以尝试使用UTF-8编码格式,因为它支持各种语言和字符。2. 检查数据源:确保数据源中的数据没有乱码。如果数据源中存在乱码,导出的文件
2023-09-13

Docker报错Operation not permitted问题的解决方法

刚开始接触Docker的朋友经常会遇到问题,下面这篇文章主要给大家介绍了关于Docker报错Operation not permitted问题的解决方法,需要的朋友可以参考下
2023-02-05

开发微信小程序之HTTPS报错常见问题汇总及解决方法

开发微信小程序之HTTPS报错常见问题汇总及解决方法今年年初,微信小程序正式上线,在微信的光芒照射下,微信小程序已经广为人知。从而越来越多的开发人员投身与微信小程序的开发工作中。在开发的过程中,总会碰到各种各样的情况。其中由于微信小程序要求
2023-06-04

MySQL8.0报错Public Key Retrieval is not allowed的原因及解决方法

目录方式一:方式二:这个问题出现原因,我在升级了mysqwww.lsjlt.coml之后发现连mysql时后台报错,报的就是标题这个错,然后就上网查资料,官网文档机翻后原因如下:如果用户帐户使用sha256_密码认证,则在传输过程中必须保
MySQL8.0报错Public Key Retrieval is not allowed的原因及解决方法
2024-02-01

pyqt5安装报错的常见问题及解决办法

随着Python的流行,PyQt5成为了很多人快速进行GUI开发的首选工具之一,但是,安装问题也是不可避免的。以下是几个PyQt5安装的常见问题及其解决方法。PyQt5安装时报错提示找不到sip模块的解决办法这个问题通常在使用pip安装
pyqt5安装报错的常见问题及解决办法
2024-01-19

MySQL8.0报错Public Key Retrieval is not allowed的原因及解决方法

MySQL8.0中“PublicKeyRetrievalisnotallowed”错误通常由TLS/SSL未启用、公钥检索已禁用或网络配置问题引起。解决方法包括启用TLS/SSL、启用公钥检索、检查网络配置、使用SSH隧道、检查服务器日志或联系服务器管理员。
MySQL8.0报错Public Key Retrieval is not allowed的原因及解决方法
2024-04-02

vue-cli空格报错问题的分析及解决办法

作为前端开发者,我们经常会使用到 Vue.js 框架,而在 Vue.js 开始学习阶段,我们更多时候会借助 vue-cli 工具来快速构建和管理项目,然而 vue-cli 工具在使用过程中,我们也可能会遇到一些问题。本篇文章就来跟大家分享一下在使用 vue-cli 时遇到的空格报错问题及其解决方法。一、问题现象在使用 vue-cli 构建项目时,有时会遇到以下错误提示:```E
2023-05-14

深入android中The connection to adb is down的问题以及解决方法

自己总结的在android中常会出现的不好解决的问题和方法1.报错:BUILD FAILEDD:\workspace\ganji\build.xml:144: The following error occurred while execu
2022-06-06

IntelliJIDEARun时报“无效的源发行版:16“错误问题及解决方法

这篇文章主要介绍了IntelliJIDEARun时报“无效的源发行版:16“错误问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-19

编程热搜

目录