如何使用React,透传各类组件能力/属性?
在23年的时候,我主要使用的框架还是Vue,当时写了一篇“如何二次封装一个Vue3组件库?”的文章,里面涉及了一些如何使用Vue透传组件能力的方法。在我24年接触React之后,我发现这种扩展组件能力的方式有一个专门的术语:高阶组件(HOC)。但在Vue开发中,这个词很少听到。
这篇文章中会描述使用React透传组件各类能力的方式。这些透传方式经常在高阶组件中使用,但并不只有高阶组件会用到它们。React有类式组件和函数式组件两种,我们会分别介绍。
问题描述
首先我们列举下简单的场景,说明我们为什么需要透传组件能力。这里以函数式组件为例。
// 问题示例,这段代码是不正确的
import { useRef } from "react";function FunComp() {return <input />;
}function FunComp2() {return <div><input /></div>;
}function App() {const refFun = useRef(null);const handleClick = () => {console.log("click");};const handleClickFocus = () => {if (refFun.current) refFun.current?.focus();};return (<div><FunCompref={refFun}style={{ background: "red" }}onClick={handleClick}/><div onClick={handleClickFocus}>点我聚焦</div></div>);
}
假设我们想创建一个自定义组件(FunComp),里面封装了另外一个组件(例如这里的input),希望使用这个自定义组件增强原组件的能力,或者预先设定一些样式等等,自定义组件可能直接返回该组件,也可能被处理过(例如FunComp2被div包裹)。
虽然原组件被封装了,但是还希望原组件的能力直接被透传给自定义组件。例如我们在自定义组件上操作props, 事件,ref等,希望就像操作原组件一样。在Vue3中,很多能力可以直接使用Attributes继承特性,但是React却没有,需要我们自己实现。
函数式组件-透传Props和事件
在函数式组件中,prop实际上就是组件的入参,且所有prop是被包含在同一个参数中的,因此很容易透传给子组件。且事件本身实际上也是prop,可以一并透传。
function FunComp(props) {return <input {...props} />;
}function App() {const handleClick = () => {console.log("click");};return (<div><FunComp style={{ background: "red" }} onClick={handleClick} /></div>);
}
使用{...props}
可以实现透传Props和事件。上述例子中,子组件可以接收到样式属性和事件。
函数式组件-透传子节点
React中有一个特殊的属性children,表示父组件中包含的子节点。这也是需要透传的。
直接渲染children属性
function FunComp(props) {return <div>左 {props.children} 右</div>;
}function App() {return (<div><FunComp>子节点</FunComp><FunComp /></div>);
}
可以看到,直接渲染props.children,即可透传子节点。即使没有子节点,这种透传也是没问题的。如果子组件本身已经透传了props,透传的对象又是
使用透传Props实现透传子节点
既然children也是Props之一,那么直接使用透传Props的方法是否可以呢? 我们试一下。
function FunComp(props) {return <div>左 {props.children} 右</div>;
}function FunComp1(props) {return <div {...props} />;
}function FunComp2(props) {return <FunComp {...props} />;
}function App() {return (<div><FunComp1>子节点</FunComp1><FunComp1 children="子节点" /><FunComp2>子节点</FunComp2><FunComp2 children="子节点" /></div>);
}/* 页面效果
子节点
子节点
左 子节点 右
左 子节点 右
*/
FunComp1包含的子组件是一个非自定义组件div,FunComp2包含的时自定义组件FunComp,可以看到我们使用{...props}
进行Props透传,children实际上都被成功渲染了,甚至对父组件直接设置children属性也可以。
冲突场景
既然Props透传即可实现,那我们为什么还要强调一遍直接渲染props.children呢,因为有时候子组件不只渲染children,还有其它内容。如果Props和直接设置的子节点冲突,那么还是直接设置的子节点优先级更高。
function FunComp(props) {return <div {...props}>左 {props.children} 右</div>;
}function App() {return (<div><FunComp>子节点</FunComp><FunComp children="子节点" /></div>);
}/* 页面效果
左 子节点 右
左 子节点 右
*/
我们同时透传了Props,也直接设置了子节点(其中包含其它内容),最后直接设置的子元素生效了。
函数式组件-透传ref
使用ref可以操作访问DOM节点,获取DOM元素上的属性或者方法。ref也是可以透传的。
透传全部属性
import { forwardRef, useRef } from "react";const FunComp = forwardRef(function (props, ref) {return <input ref={ref} />;
});function App() {const inputRef = useRef(null);function handleClick() {console.log(inputRef.current?.style);inputRef.current?.focus();}return (<div><FunComp ref={inputRef} /><div onClick={handleClick}>点击聚焦</div></div>);
}
使用forwardRef,可以透传ref属性。我们尝试了聚焦输入框,以及console输出style属性,都是正常生效的。
仅暴露部分属性
有时候我们不想暴露全部属性,仅希望暴露我们希望用户使用的部分属性,使用useImperativeHandle可以做到。
import { forwardRef, useRef, useImperativeHandle } from "react";const FunComp = forwardRef(function (props, ref) {const inputRef = useRef(null);useImperativeHandle(ref, () => {return {focus() {inputRef.current?.focus();},};});return <input ref={inputRef} />;
});function App() {const inputRef = useRef(null);function handleClick() {// 无法输出console.log(inputRef.current?.style);inputRef.current?.focus();}return (<div><FunComp ref={inputRef} /><div onClick={handleClick}>点击聚焦</div></div>);
}
我们仅向外层的ref暴露了focus,因此外层组件focus可以正常调用,但是却拿不到style属性了。使用这种形式还可以对方法进行额外的包装,或者创建一些新的ref方法。
在React19中,不再需要forwardRef了,ref直接作为一个prop属性访问。可以看最后的参考文档。
类式组件-透传Props和事件
类式组件是另一种创建React组件的方法,被React标记为过时的API,但是在老代码中还经常被使用到。我们先来看一下,在类式组件中,如何Props和事件。
import { Component } from "react";
class ClassComp extends Component {render() {return <div {...this.props}>你好</div>;}
}class App extends Component {render() {const handleClick = () => {console.log("click");};return <ClassComp style={{ background: "red" }} onClick={handleClick} />;}
}
通过上述代码可以看到,在类式组件中透传Props和事件与函数式组件一致,使用{...props}
可以实现透传Props和事件。
类式组件-透传子节点
来看看类式组件是如何透传子节点的。
直接渲染children属性
import { Component } from "react";
class ClassComp extends Component {render() {return <div>左 {this.props.children} 右</div>;}
}class App extends Component {render() {return (<div><ClassComp>子节点</ClassComp><ClassComp /></div>);}
}
代码依然与类式组件基本一致,直接渲染{this.props.children}
即可。
使用透传Props实现透传子节点
上一节讲到的透传Props,同样可以实现透传子节点。
import { Component } from "react";
class ClassComp extends Component {render() {return <div>左 {this.props.children} 右</div>;}
}
class ClassComp1 extends Component {render() {return <div {...this.props} />;}
}
class ClassComp2 extends Component {render() {return <ClassComp {...this.props} />;}
}class App extends Component {render() {return (<div><ClassComp1>子节点</ClassComp1><ClassComp1 children="子节点" /><ClassComp2>子节点</ClassComp2><ClassComp2 children="子节点" /></div>);}
}/* 页面效果
子节点
子节点
左 子节点 右
左 子节点 右
*/
与函数式组件一致,Props透传时也会透传children,甚至对父组件直接设置children属性也可以透传。至于Props和直接设置的子节点冲突的场景也与函数式组件一致,这里就不举例了。
类式组件-透传ref
类式组件透传Ref的形式就与函数式组件不同了。具体类式组件有不同的实现方式,我们分别介绍下:
暴露部分属性
import { Component, createRef } from "react";class ClassComp extends Component {inputRef = createRef();focus() {this.inputRef.current?.focus();}render() {return <input ref={this.inputRef} />;}
}class App extends Component {classRef = createRef();handleClick() {console.log(this.classRef.current);this.classRef.current?.focus();}render() {return (<div><ClassComp ref={this.classRef} /><div onClick={() => this.handleClick()}>点击聚焦</div></div>);}
}
通过代码可以看到,在类式组件中,不需要通过forwardRef等方法就可以使用ref访问子组件,且能执行子组件类中的方法。所以我们只要把需要暴露的内容包装成一个方法,那么就可以让父组件获取到。
通过输出的图可以看到,不仅能拿到方法,还能拿到属性和其它很多东西。
拿到子组件内部的ref
既然可以拿到子组件类中和属性也能拿到。那么父组件可以直接拿到子组件内部的ref属性inputRef,父组件可以直接拿到它来执行内部的方法。
import { Component, createRef } from "react";class ClassComp extends Component {inputRef = createRef();render() {return <input ref={this.inputRef} />;}
}class App extends Component {classRef = createRef();handleClick() {this.classRef.current?.inputRef?.current?.focus();}render() {return (<div><ClassComp ref={this.classRef} /><div onClick={() => this.handleClick()}>点击聚焦</div></div>);}
}
通过代码可以看到,子组件不需要透出方法了,父组件直接拿到子组件的inputRef,想执行什么就执行什么,做到了真正的“透传”。绑定ref还有另一种方式,这里也介绍一下:
import { Component, createRef } from "react";class ClassComp extends Component {render() {return <input ref="inputRef" />;}
}class App extends Component {classRef = createRef();handleClick() {this.classRef.current?.refs?.inputRef?.focus();}render() {return (<div><ClassComp ref={this.classRef} /><div onClick={() => this.handleClick()}>点击聚焦</div></div>);}
}
ref属性的值可以直接是一个字符串,通过this.refs可以拿到使用字符串形式绑定的ref。
总结
函数式组件与类式组件在Props和事件透传的方式基本一致,但是ref透传的区别较大。直接对比的话,好像类式组件的透传能力更强一些,但是它把组件内部所有内容全暴露在外,违反了封装的原则,子组件内部的改动很容易影响父组件,不是一个好的设计。
在React19版本中,ref属性也变成了prop,仅通过透传Props,就能实现透传组件大部分能力了。
参考
- 如何二次封装一个Vue3组件库?
https://jzplp.github.io/2023/component-lib.html - Vue3 透传Attributes
https://cn.vuejs.org/guide/components/attrs - React 使用ref操作DOM
https://zh-hans.react.dev/learn/manipulating-the-dom-with-refs - React omponent
https://zh-hans.react.dev/reference/react/Component - ref用法
https://blog.csdn.net/qq_47305413/article/details/136059266 - React v19 ref作为一个属性
https://zh-hans.react.dev/blog/2024/12/05/react-19#ref-as-a-prop
相关文章:
如何使用React,透传各类组件能力/属性?
在23年的时候,我主要使用的框架还是Vue,当时写了一篇“如何二次封装一个Vue3组件库?”的文章,里面涉及了一些如何使用Vue透传组件能力的方法。在我24年接触React之后,我发现这种扩展组件能力的方式有一个专门的术语&am…...
C# 6.0版本的WebAPI接口部署到Linux服务器
将 C# 6.0 的 Web API 部署到 Linux 服务器涉及多个步骤,包括准备环境、构建和发布应用程序、配置 Web 服务器以及确保应用程序正常运行。以下是详细的部署指南: 1. 准备开发环境 安装 .NET SDK 确保你已经在本地开发环境中安装了 .NET SDK(…...
ArkTs组件(2)
一.下拉列表组件:Select 1.接口 Select(options: Array<SelectOption>) 参数名类型必填说明optionsArray<SelectOption>是设置下拉选项。 SelectOption对象说明 名称类型必填说明valueResourceStr是 下拉选项内容。 iconResourceStr否 下拉选项图片…...
Bash 脚本教程
注:本文为 “Bash 脚本编写” 相关文章合辑。 BASH 脚本编写教程 as good as well于 2017-08-04 22:04:28 发布 这里有个老 American 写的 BASH 脚本编写教程,非常不错,至少没接触过 BASH 的也能看懂! 建立一个脚本 Linux 中有…...
SQL创建和操纵表
本文介绍创建、更改和删除表的基本知识。 1. 创建表 SQL 不仅用于表数据操纵,而且还用来执行数据库和表的所有操作,包括表本身的创建和处理。一般有两种创建表的方法: 多数DBMS 都具有交互式创建和管理数据库表的工具;表也可以…...
1.微服务灰度发布(方案设计)
前言 微服务架构中的灰度发布(也称为金丝雀发布或渐进式发布)是一种在不影响现有用户的情况下,逐步将新版本的服务部署到生产环境的策略。通过灰度发布,你可以先将新版本的服务暴露给一小部分用户或特定的流量,观察其…...
QT笔记- QTreeView + QFileSystemModel 当前位置的保存与恢复 #选中 #保存当前索引
保存当前位置 QString currentPath model->filePath(view->currentIndex()); // 获得当前位置路径 恢复位置 view->setCurrentIndex(model->index(currentPath)); // 设置此路径所在位置为当前位置...
LeetCode - Google 校招100题 第6天 回溯法(Backtracking) (8题)
欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/144743505 LeetCode 合计最常见的 112 题: 校招100题 第1天 链表(List) (19题)校招100题 第2天 树(Tree) (21题)校招100题 第3天 动态规划(DP) (20题)...
k8s,service如何找到容器
Kubernetes之所以需要Service,一方面是因为Pod的IP不是固定的,另一方面则是因为一组Pod实例之间总会有负载均衡的需求 被selector选中的Pod,就称为Service的Endpoints,查看方式: kubectl get endpoints hostnames需要…...
计算机的错误计算(一百九十二)
摘要 用两个大模型计算 csc(0.999), 其中,0.999是以弧度为单位的角度,结果保留5位有效数字。两个大模型均给出了 Python代码与答案。但是,答案是错误的。 例1. 计算 csc(0.999), 其中,0.999是以弧度为单位的角度,结…...
金仓数据库安装-Kingbase v9-centos
在很多年前有个项目用的金仓数据库,上线稳定后就没在这个项目了,只有公司的开发环境还在维护,已经好多年没有安装过了,重温一下金仓数据库安装,体验一下最新版本,也做一个新版本的试验环境; 一、…...
深入解析 Java 中的 getDeclaredMethods() 方法:使用与原理全攻略
在 Java 的反射机制中,getDeclaredMethods() 是一个非常重要的方法,它允许我们获取类中声明的所有方法(包括公共、私有、保护以及默认访问权限的方法)。通过这个方法,我们可以动态地分析和操作类的行为,这在…...
Dockerfile的用法
Dockerfile的用法 示例 `Dockerfile`使用 `Dockerfile` 创建 Docker 镜像`Dockerfile` 指令详解其他常用指令总结Dockerfile 是一个文本文件,包含了用于创建 Docker 镜像的一系列指令。这些指令描述了镜像的基础、所安装的软件、文件的复制、环境变量的设置以及其他配置。下面…...
Gmsh有限元网格剖分(Python)---点、直线、平面的移动
Gmsh有限元网格剖分(Python)—点、直线、平面的移动和旋转 最近在学习有限元的网格剖分算法,主要还是要参考老外的开源Gmsh库进行,写一些博客记录下学习过程,方便以后回忆嘞。 Gmsh的官方英文文档可以参考:gmsh.pdf 但咋就说&a…...
AI的进阶之路:从机器学习到深度学习的演变(三)
(承接上集:AI的进阶之路:从机器学习到深度学习的演变(二)) 四、深度学习(DL):机器学习的革命性突破 深度学习(DL)作为机器学习的一个重要分支&am…...
如何通过 360 驱动大师检查自己电脑上的显卡信息
在深入探讨如何查看显卡信息之前,首先需要了解显卡的基本概念。显卡(Graphics Processing Unit, GPU),是计算机中负责处理图形输出到显示器的重要硬件。根据其集成度和性能,显卡通常被分为两类: 集成显卡&…...
数据仓库工具箱—读书笔记02(Kimball维度建模技术概述04、使用一致性维度集成)
Kimball维度建模技术概述 记录一下读《数据仓库工具箱》时的思考,摘录一些书中关于维度建模比较重要的思想与大家分享🤣🤣🤣 第二章前言部分作者提到:技术的介绍应该通过涵盖各种行业的熟悉的用例展开(赞同…...
.net framework wpf 打包免安装exe文件
1、打开所在项目csproj文件添加以下内容: <Target Name"AfterResolveReferences"><ItemGroup><EmbeddedResource Include"(ReferenceCopyLocalPaths)" Condition"%(ReferenceCopyLocalPaths.Extension) .dll"><…...
瑞吉外卖项目学习笔记(八)修改菜品信息、批量启售/停售菜品
瑞吉外卖项目学习笔记(一)准备工作、员工登录功能实现 瑞吉外卖项目学习笔记(二)Swagger、logback、表单校验和参数打印功能的实现 瑞吉外卖项目学习笔记(三)过滤器实现登录校验、添加员工、分页查询员工信息 瑞吉外卖项目学习笔记(四)TableField(fill FieldFill.INSERT)公共字…...
Oracle 日常巡检
1. 检查服务器状态 1.1. CPU使用情况 1.1.1. top top 命令是 Linux 和 Unix 系统中用于显示实时系统状态的工具,特别是对于监控 CPU 和内存的使用非常有用。 在命令行中输入 top,top 会显示一个实时更新的界面,其中包含系统的关键指标&am…...
CS 144 check7: putting it all together
Exercises 经验:两边的TCP连接建立得尽快,如果服务器端启动了,客户端没有启动就连不上。。 服务器端: 客户端: 文件收发测试: 参考: CS 144CS144 | Winter 2024, Lab 0~7 记录࿰…...
springboot数据校验报错
目录 报错信息 原因 解决 报错信息 springboot在进行数据校验的时候ConfigurationProperties注解形式下Email报错 Caused by: javax.validation.UnexpectedTypeException: HV000030: No validator could be found for constraint javax.validation.constraints.Email valid…...
mapbox基础,加载天地图矢量底图
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象…...
SLAM/数字图象处理基础
概念 视差:相同特征的不同深度估计的偏差 BoW,DBoW,DBoW2的区别是什么 Bag of Words (BoW)、DBoW(Dynamic Bag of Words)和DBoW2是用于图像处理和计算机视觉中的不同特征表示和匹配方法。它们之间的主要区别如下&am…...
修改vue-element-admin,如何连接我们的后端
改哪几个文件就可以连接我们后端 主要就这四个 main.js,屏蔽这个或者删除 vue-config 最后两个文件改下端口即可 这样基本就能发了,但是还要改下 改成api 然后还要修改request.js 这里改成我们返回的状态码 我讲一个东西很容易就懂了&…...
基于PLC的采摘机械手系统(论文+源码)
1系统方案设计 本次设计围绕基于PLC的采摘机械手系统进行设计, PLC即可编程控制器其是一种常见的微处理器,本次拟采用西门子是S7-200 PLC,一方面对整个设计从器件选型到I/O分配,图纸绘制等进行设计,另一方面还通过组态…...
使用ArcGIS/ArcGIS pro绘制六边形/三角形/菱形渔网图
在做一些尺度分析时,经常会涉及到对研究区构建不同尺度的渔网进行分析,渔网的形状通常为规则四边形。构建渔网的方法也很简单,使用ArcGIS/ArcGIS Pro工具箱中的【创建渔网/CreateFishnet】工具来构建。但如果想构建其他形状渔网进行相关分析&…...
【5/6 面向应用相关的优化 网卡实现及评估 】
5 面向应用相关的优化 面对数据中心多样化的部署需求和应用场景,如分布式存储、多租户性能隔离等,构建高性能的RDMA系统需要仔细选择传输模式和通信原语以充分发挥其性能优势,并调整软硬件结构进行适配.整体手段:在软件层面结合R…...
如何识别钓鱼邮件和诈骗网站?(附网络安全意识培训PPT资料)
识别钓鱼邮件和诈骗网站是网络安全中的一个重要环节。以下是一些识别钓鱼邮件和诈骗网站的方法: 识别钓鱼邮件: 检查发件人地址: 仔细查看发件人的电子邮件地址,看是否与官方域名一致。 检查邮件内容: 留意邮件中是否…...
TOGAF之架构标准规范-业务架构
TOGAF标准规范中,业务架构阶段的主要工作是开发支持架构愿景的业务架构。 如上所示,业务架构(Business Architecture)在TOGAF标准规范中处于B阶段,该阶段的主要内容包括阶段目标、阶段输入、流程步骤、架构方法。 阶段…...
嵌入式轻量级开源操作系统:HeliOS的使用
嵌入式轻量级开源操作系统:HeliOS的使用 📍项目地址:https://github.com/heliosproj/HeliOS HeliOS项目是一个社区交付的开源项目,用于构建和维护HeliOS嵌入式操作系统(OS)。HeliOS是一个功能齐全的操作系统࿰…...
mysql 数据库迁移到达梦数据库
1.windows安装达梦数据库,去官网下载 dm8 进行安装,安装后,可以使用管理工具管理数据 使用迁移工具对数据进行迁移; 2.使用php 或者 thinkphp连接达梦数据库 2.1、先PHP开启DM扩展 从达梦数据库安装目录下drivers/php_pdo 复制对…...
Java中的异常处理机制
今天想和大家探讨Java中的异常处理机制。异常处理是任何编程语言中不可或缺的一部分,它帮助我们处理程序运行时可能出现的错误,确保程序的健壮性和稳定性。Java作为一种强类型、面向对象的编程语言,提供了一套完整的异常处理框架。 1. 异常的…...
iOS 苹果开发者账号: 查看和添加设备UUID 及设备数量
参考链接:苹果开发者账号下添加新设备UUID - 简书 如果要添加新设备到 Profiles 证书里: 1.登录开发者中心 Sign In - Apple 2.找到证书设置: Certificate,Identifiers&Profiles > Profiles > 选择对应证书 edit &g…...
数据仓库工具箱—读书笔记02(Kimball维度建模技术概述03、维度表技术基础)
Kimball维度建模技术概述 记录一下读《数据仓库工具箱》时的思考,摘录一些书中关于维度建模比较重要的思想与大家分享🤣🤣🤣 第二章前言部分作者提到:技术的介绍应该通过涵盖各种行业的熟悉的用例展开(赞同…...
Linux中常用的Shell脚本(运维+常用)汇总
废话不多说,直接上干货! 一、运维脚本 (1)监控CPU和内存的使用情况 #!/bin/bashcpu_threshold80 mem_threshold80# 获取CPU和内存使用率 cpu_usage$(top -bn1 | grep "Cpu(s)" | sed "s/.*, *\([0-9.]*\)%* id.…...
Java 方法注释:规范、实用和高质量的写法
目录 为什么要注释方法? 方法注释的基本要求 Javadoc 注释格式 示例:一个计算圆面积的方法 代码示例 注释分析 如何写出高质量的 Java 方法注释? 1. 关注可读性 2. 使用 Javadoc 格式 3. 描述异常 4. 适当的解释复杂的算法 5. 避…...
解决JIRA、Confluence用户自动注销、反复登录的问题
一、问题描述:当工作从从confluence里面打开jira的时候,在回到confluence时候,就自动退出了,需要账号密码登录重复登录,使人十分厌恶。 二、原因分析: 访问 JIRA、Confluence 或任何其他具有相同域或 IP 上…...
Python9-作业2
记录python学习,直到学会基本的爬虫,使用python搭建接口自动化测试就算学会了,在进阶webui自动化,app自动化 python基础8-灵活运用顺序、选择、循环结构 作业2九九乘法表三种方式打印九九乘法表使用两个嵌套循环使用列表推导式和…...
基于c语言的union、字符串、格式化输入输出
结构体之共用体union 共用体也叫联合体,其关键词为union 与结构体不同的是,共用体所开辟的存储空间仅仅为其中最长类型变量的存储空间而不是全部变量的存储空间,由于同一内存单元在同一时间内只能存放其中一种的数据类型,因此在每…...
SpringCloudAlibaba实战入门之路由网关Gateway初体验(十)
Spring Cloud 原先整合 Zuul 作为网关组件,Zuul 由 Netflix 公司提供的,现在已经不维护了。后面 Netflix 公司又出来了一个 Zuul2.0 网关,但由于一直没有发布稳定版本,所以 Spring Cloud 等不及了就自己推出一个网关,已…...
活着就好20241227
亲爱的朋友们,大家早上好!🌞 今天是27号,星期五,2024年12月的第二十七天,同时也是第51周的第五天,农历甲辰[龙]年十一月初二十三日。在这晨光渐浓的美好时刻,愿那温暖而明媚的阳光洒…...
robotframework中的测试套件
一. 简介 本文简单来了解一下,robotframework中的测试套件。 二. robotframework中测试套件 1. 什么是测试套件? 测试套件(Test Suite) 是一组相关测试用例的集合。每个测试套件通常代表一个特定的功能模块、系统组件或业务流程…...
Echarts连接数据库,实时绘制图表详解
文章目录 Echarts连接数据库,实时绘制图表详解一、引言二、步骤一:环境准备与数据库连接1、环境搭建2、数据库连接 三、步骤二:数据获取与处理1、查询数据库2、数据处理 四、步骤三:ECharts图表配置与渲染1、配置ECharts选项2、动…...
【QED】爱丽丝与混沌的无尽海
文章目录 题目题目描述输入输出格式数据范围测试样例 思路代码复杂度分析时间复杂度空间复杂度 题目 题目链接🔗 题目描述 如图所示,爱丽丝在一个3x3的迷宫之中,每个方格中标有 1 − 9 1-9 1−9各不相同的数字,爱丽丝可以从一格…...
CHM助手 >> 如何安装CHM助手
1 如何安装CHM助手 下载CHM助手.ezip,下载地址打开EverEdit,选择主菜单“扩展 -> 扩展管理 -> 从本地文件安装扩展”,在弹出的文件浏览窗口中选择插件安装包,如下图所示: 🕮说明: …...
硬件设计:LVDS电平标准
什么是LVDS? LVDS(Low-Voltage Differential Signaling)是一种高速、低功耗的差分信号传输标准。它通过一对差分信号线(通常是两根互补信号线)来传输数据,广泛应用于高速数字通信领域。 LVDS 的核心特点 低…...
宝塔-firefox(Docker应用)-构建自己的Web浏览器
安装基础软件 宝塔中安装firefox(Docker应用) 。宝塔中需要先安装docker及docker-composefirefox配置安装 点击firefox应用,选择【安装配置】点击右边绿色按钮,进行安装,这一步等待docker-compose根据你的配置初始化docker应用 等待安装 …...
微信小程序-基于Vant Weapp UI 组件库的Area 省市区选择
Area 省市区选择,省市区选择组件通常与 弹出层 组件配合使用。 areaList 格式 areaList 为对象结构,包含 province_list、city_list、county_list 三个 key。 每项以地区码作为 key,省市区名字作为 value。地区码为 6 位数字,前两…...
宏转录组+HiFi宏基因组:揭示厌氧消化中的碳流和能量转换
厌氧消化是一种重要的工程生物技术,对有机废物的资源回收和可再生能源的生产起着关键作用。然而,由于对未培养的厌氧菌及其适应环境变化的能力了解有限,这限制了该技术的优化和生物气生产的可持续性。今天小编带大家看一篇发表在《Microbiome…...