- 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 - findRenderedDOMComponentWithClass()
在 ReactJS 中,findRenderedDOMComponentWithClass() 方法用于测试。它帮助我们在 DOM 中找到具有特定 CSS 类的渲染组件。此方法主要用于测试 React 组件。
在为我们的 React 组件编写测试时,我们可以检查具有给定 CSS 类的组件是否出现在渲染的输出中。这正是 findRenderedDOMComponentWithClass() 所做的。因此,我们将渲染的组件和我们想要的 CSS 类传递给此函数。然后返回具有该类的第一个 DOM 元素。
请记住,此函数在以前版本的 React 和测试框架中更常用。更多当前的测试库可以提供不同的方法来实现相同的目标。
语法
findRenderedDOMComponentWithClass(
tree,
className
)
参数
- tree - 它是我们想要在其中搜索的显示组件或组件树。它是我们的 React 组件的渲染输出,从测试库接收。
- className - 一个字符串,表示我们想要在树中找到的CSS类。该方法将搜索具有此特定类的 DOM 元素。
返回值
该方法将返回具有给定类的第一个 DOM 元素,允许我们使用其他操作或断言继续测试。
例子
示例 - 基本React应用程序
应用说明:这就像一个网页,在网页上显示“你好,反应!想象一下,这是一张简单的贺卡。
测试说明 - 我们希望确保贺卡的特定部分(段落)在那里。因此,我们使用一个工具来找到该部分并检查它是否是我们想要的。
App.js
import React from 'react';
import './App.css';
function App() {
return (
<div className="app-container App">
<h1>Hello, React!</h1>
<p className="app-paragraph">This is a simple React app.</p>
</div>
);
}
export default App;
App.test.js
import { render } from '@testing-library/react';
import findRenderedDOMComponentWithClass from 'path-to-findRenderedDOMComponentWithClass';
import App from './App';
test('finds a paragraph with a specific class', () => {
const { container } = render(<App />);
const foundElement = findRenderedDOMComponentWithClass(container, 'app-paragraph');
// Now we can make assertions or tests based on foundElement
});
输出
示例 - 带有组件的React应用程序
应用程序说明 - 在应用程序中,假设我们有一个网页,并且该网页有一个标题(标题)和一个段落。它就像一个顶部有一个标题的小网站。
测试说明 - 我们希望确保标题在那里。因此,我们使用一个工具来查找标题并检查它是否在正确的位置。
Header.js
import React from 'react';
function Header() {
return <h1 className="header-title">Welcome to My App</h1>;
}
export default Header;
App.js
import React from 'react';
import Header from './Header';
import './App.css';
export default function App() {
return (
<div className="app-container">
<Header />
<p className="app-paragraph">This app has a header component.</p>
</div>
);
}
App.test.js
import { render } from '@testing-library/react';
import findRenderedDOMComponentWithClass from 'path-to-findRenderedDOMComponentWithClass';
import App from './App';
test('finds a header with a specific class', () => {
const { container } = render(<App />);
const foundElement = findRenderedDOMComponentWithClass(container, 'header-title');
});
输出
示例 - 具有动态内容的React应用程序
应用程序说明 - 这就像一个可以显示不同消息的网页。它有点像一个招牌,可以显示不断变化的信息。
测试说明 - 我们希望确保存在不断变化的消息。因此,我们使用一个工具来找到该部分并检查它是否显示正确的信息。
DynamicContent.js
import React from 'react';
function DynamicContent({ content }) {
return <div className="dynamic-content">{content}</div>;
}
export default DynamicContent;
App.js
import React from 'react';
import DynamicContent from './DynamicContent';
import './App.css';
function App() {
return (
<div className="app-container App">
<DynamicContent content="This content is dynamic!" />
<p className="app-paragraph">This app includes dynamic content.</p>
</div>
);
}
App.test.js
import { render } from '@testing-library/react';
import findRenderedDOMComponentWithClass from 'path-to-findRenderedDOMComponentWithClass';
import App from './App';
test('finds a dynamic content with a specific class', () => {
const { container } = render(<App />);
const foundElement = findRenderedDOMComponentWithClass(container, 'dynamic-content');
});
输出
总结
此函数用于测试 React 组件。当我们运行测试时,它可以帮助我们在 React 组件的最终结果中找到特定元素。假设我们有一群人的照片,我们想找到一个戴着红帽子的人,我们将使用这个函数来定位图片中的那个人。它是一个有用的测试工具,可以确保我们的组件按预期运行。