- 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 - 使用 React Hooks 进行状态管理
- ReactJS - 使用 React Hooks 进行组件生命周期管理
- ReactJS - 布局组件
- ReactJS - 分页
- ReactJS - Material UI
- ReactJS - Http 客户端编程
- ReactJS - 表单编程
- ReactJS - 受控组件
- ReactJS - 非受控组件
- ReactJS - Formik
- ReactJS - 条件渲染
- ReactJS - 列表
- ReactJS - Keys
- ReactJS - 路由
- ReactJS - Redux
- ReactJS - 动画
- ReactJS - Bootstrap
- ReactJS - 地图
- 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 - Context
- ReactJS - 错误边界
- ReactJS - 转发 Refs
- ReactJS - 片段
- ReactJS - 高阶组件
- ReactJS - 集成其他库
- ReactJS - 优化性能
- ReactJS - Profiler API
- ReactJS - Portals
- ReactJS - 无 ES6 ECMAScript 的 React
- ReactJS - 无 JSX 的 React
- ReactJS - 调和
- ReactJS - Refs 和 DOM
- ReactJS - 渲染 Props
- ReactJS - 静态类型检查
- ReactJS - 严格模式
- ReactJS - Web Components
- 其他概念
- ReactJS - 日期选择器
- ReactJS - Helmet
- ReactJS - 内联样式
- ReactJS - PropTypes
- ReactJS - BrowserRouter
- ReactJS - DOM
- ReactJS - 走马灯
- ReactJS - 图标
- ReactJS - 表单组件
- ReactJS - 参考 API
- ReactJS 有用资源
- ReactJS - 快速指南
- ReactJS - 有用资源
- ReactJS - 讨论
ReactJS - scryRenderedDOMComponentsWithTag() 函数
scryRenderedDOMComponentsWithTag() 函数是 React 编程工具,用于查找和收集有关网页特定元素的信息。它只是计算机程序员搜索网站上特定项目的的一种方法。此 scryRenderedDOMComponentsWithTag() 函数搜索具有特定标签名称的项目,例如按钮、图像或段落。
因此,当我们使用 scryRenderedDOMComponentsWithTag(tree, tagName) 时,我们是在指示系统在“tree”中搜索任何具有给定“tagName”的项目。
假设我们有一个大型的复杂网页,并且想要查找其中的所有按钮。我们可以使用 scryRenderedDOMComponentsWithTag() 来处理所有工作,而不是手动搜索。
语法
scryRenderedDOMComponentsWithTag( tree, tagName )
参数
该函数考虑了两个重要方面:tree 和 tagName。
tree − tree 就像网页的地图,显示了所有不同的部分以及它们如何连接。
tagName − tagName 只是我们感兴趣的元素类型的名称,例如 div 或 p。
返回值
scryRenderedDOMComponentsWithTag() 函数返回渲染树中所有与指定标签名称匹配的 DOM(文档对象模型)元素的列表。
以下是一些使用 scryRenderedDOMComponentsWithTag() 方法的简单 React 应用,以及每个应用的简要说明 -
示例
示例 - 按钮计数器应用
此应用显示一个按钮和一个计数。因此,当我们单击按钮时,它将递增计数。为了在 React 中测试 scryRenderedDOMComponentsWithTag(),我们通常会使用 Jest 或 React Testing Library 等测试库。因此,以下是应用和测试的代码 -
ButtonCounter.js
import React, { useState } from 'react'; import './App.css'; const ButtonCounter = () => { const [count, setCount] = useState(0); return ( <div className='App'> <p>Count: {count}</p> <button onClick={() => setCount(count + 1)}>Increment</button> </div> ); }; export default ButtonCounter;
按钮计数器应用的测试代码
import React from 'react'; import { render, scryRenderedDOMComponentsWithTag } from '@testing-library/react'; import ButtonCounter from './ButtonCounter'; test('renders ButtonCounter component', () => { const { container } = render(<ButtonCounter />); const buttons = scryRenderedDOMComponentsWithTag(container, 'button'); expect(buttons.length).toBe(1); });
输出
示例 - 待办事项列表应用
该应用程序允许我们创建和显示待办事项列表。我们可以通过在文本框中输入待办事项并单击“添加待办事项”按钮来将新的待办事项添加到列表中。因此,以下是 React 应用的代码,以及我们创建的特定应用的测试 -
TodoList.js
import React, { useState } from 'react'; import './App.css' const TodoList = () => { const [todos, setTodos] = useState([]); const [newTodo, setNewTodo] = useState(''); const addTodo = () => { setTodos([...todos, newTodo]); setNewTodo(''); }; return ( <div className='App'> <ul> {todos.map((todo, index) => ( <li key={index}>{todo}</li> ))} </ul> <input type="text" value={newTodo} onChange={(e) => setNewTodo(e.target.value)} /> <button onClick={addTodo}>Add Todo</button> </div> ); }; export default TodoList;
待办事项列表应用的测试代码
import React from 'react'; import { render, scryRenderedDOMComponentsWithTag } from '@testing-library/react'; import TodoList from './TodoList'; test('renders TodoList component', () => { const { container } = render(<TodoList />); const buttons = scryRenderedDOMComponentsWithTag(container, 'button'); const input = scryRenderedDOMComponentsWithTag(container, 'input'); expect(buttons.length).toBe(1); expect(input.length).toBe(1); });
输出
示例 - 颜色选择器应用
此应用允许我们从三个选项中选择颜色:红色、绿色和蓝色。所选颜色显示在按钮下方。因此,应用及其测试的代码如下所示 -
ColorPicker.js
import React, { useState } from 'react'; const ColorPicker = () => { const [selectedColor, setSelectedColor] = useState(''); const handleColorChange = (color) => { setSelectedColor(color); }; return ( <div> <p>Selected Color: {selectedColor}</p> <button onClick={() => handleColorChange('Red')}>Red</button> <button onClick={() => handleColorChange('Green')}>Green</button> <button onClick={() => handleColorChange('Blue')}>Blue</button> </div> ); }; export default ColorPicker;
颜色选择器应用的测试代码
import React from 'react'; import { render, scryRenderedDOMComponentsWithTag } from '@testing-library/react'; import ColorPicker from './ColorPicker'; test('renders ColorPicker component', () => { const { container } = render(<ColorPicker />); const buttons = scryRenderedDOMComponentsWithTag(container, 'button'); const paragraphs = scryRenderedDOMComponentsWithTag(container, 'p'); expect(buttons.length).toBe(3); expect(paragraphs.length).toBe(1); });
输出
上面每个测试用例的描述
在上面的测试用例中 -
为了渲染每个组件,我们使用 React Testing Library 中的 render 函数。
然后使用 scryRenderedDOMComponentsWithTag 来查找渲染组件中具有某些 HTML 标签的项目。
最后,进行断言以确认具有给定标签的元素数量是否符合预期。
安装必要的测试库(@testing-library/react 和 @testing-library/jest-dom) -
npm install --save-dev @testing-library/react @testing-library/jest-dom
总结
scryRenderedDOMComponentsWithTag() 函数是 React Testing Library 中使用的一种方法,用于在渲染的 React 组件中查找和检索 DOM 元素。此函数采用两个参数:渲染的组件(容器)和我们要搜索的 HTML 标签名称。