react-testing-library - Screen vs Render queries(反应-测试-库-屏幕与呈现查询)
本文介绍了反应-测试-库-屏幕与呈现查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
使用react-testing-library
查询有两种方式。
您可以使用render
方法返回的查询:
import React from 'react'
import { render } from '@testing-library/react'
...
const { getByText } = render(<div>Foo</div>)
expect(getByText('Foo')).toBeInTheDocument()
或者您可以使用screen
对象:
import React from 'react'
import { render, screen } from '@testing-library/react'
...
render(<div>Foo</div>)
expect(screen.getByText('Foo')).toBeInTheDocument()
但文档中没有说明哪个选项是最佳选项及其原因。
有人能开导我吗?
推荐答案
react-testing-library
作者肯特·C·多兹本人推荐的最新选项是使用screen
。
使用Screen的好处是,在添加/删除所需的查询时,您不再需要保持最新的呈现调用deStructure。您只需输入Screen。让你的编辑的魔力自动完成来处理剩下的事情。
唯一的例外是如果您正在设置容器或base Element,您可能应该避免这样做(老实说,我想不出这些选项的合法用例了,此时它们的存在只是出于历史原因)。
来源:https://kentcdodds.com/blog/common-mistakes-with-react-testing-library#not-using-screen
这篇关于反应-测试-库-屏幕与呈现查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:反应-测试-库-屏幕与呈现查询
猜你喜欢
- Fetch API 如何获取响应体? 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- 400或500级别的HTTP响应 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01