React Portals 有什么用
React Portals
是React
提供的一种机制
,它允许开发者将组件渲染到DOM树中的不同位置
,而不受组件层次结构的限制
。React Portals的主要用途和优势包括以下几个方面:
用途和优势
-
处理全局UI元素
React Portals
允许将UI元素渲染到应用的根DOM之外
,这对于创建全局的UI元素
非常有用。例如,模态框、通知框、工具提示等全局元素可以浮在应用的其他组件之上
,而不会受到组件嵌套结构的影响。这有助于实现更加灵活和动态
的UI设计。 -
处理层叠上下文
在CSS中,某些样式属性(如z-index)会创建层叠上下文
,从而限制某些元素的显示顺序
。使用React Portals可以将元素渲染到指定的DOM节点上
,从而绕过这些层叠上下文的限制
。这有助于实现更复杂的UI布局,特别是在需要控制元素显示顺序的场景中。 -
处理复杂的UI布局
在某些情况下,需要将组件的渲染内容插入到DOM结构的特定位置
,以满足设计或布局需求。React Portals允许在不改变组件层次结构的情况下实现这些需求
。例如,可以将悬浮菜单或侧边栏等组件渲染到DOM树的特定位置
,而不必担心它们会破坏组件的层次结构。 -
提高组件的可重用性
使用React Portals可以将通用的UI组件(如模态框或通知框)封装为可重用
的组件。这些组件可以在不同的应用中使用
,并且不需要关心它们的放置位置
。这有助于提高代码的可维护性和复用性。 -
实现更灵活的DOM操作
React Portals提供了一种有效的方法来渲染子节点到存在于父组件DOM层次结构之外的DOM节点中
。这有助于打破传统父子组件层级的限制
,实现更加灵活和动态的DOM操作
。例如,可以在应用程序的不同部分之间共享和重用模态组件
,而无需担心它们的层级关系。 -
简化事件处理和状态管理
尽管组件被渲染到了不同的DOM节点,但React Portals仍然能够保持组件的正常生命周期和状态管理
。这意味着可以在Portal内部使用状态、事件处理程序等React功能
。此外,由于事件可以在Portals中正常冒泡
,因此可以简化事件管理,使构建具有复杂交互的组件变得更加容易
。
使用注意事项
合适的目标容器:确保选择一个合适的DOM元素作为Portal的目标容器。通常会在组件的componentDidMount
生命周期方法中将Portal添加到DOM,并在componentWillUnmount
中将其移除。
- 避免滥用:虽然React Portals提供了灵活性,但不应滥用它们。只有在必要的情况下使用Portal,以
避免过度复杂的嵌套结构
。 - 层叠上下文管理:Portal可能会破坏默认的
CSS层叠上下文
。如果Portal内容和其他元素有层叠关系,可能需要手动管理z-index或使用CSS属性来控制渲染顺序。
- 事件处理:由于Portal的内容可以渲染在组件树之外,因此
事件处理可能会受到限制
。确保事件处理程序适用于Portal内容
,或者使用事件冒泡机制来处理事件
。
React Portals优缺点的详细分析
-
优点
- 处理全局或跨层级的UI元素:
- React Portals能够轻松处理模态框、通知框、下拉菜单等全局或跨层级的UI元素,而不会破坏组件的层次结构。
- 这些元素可以浮在应用的其他组件之上,提供更好的用户体验。
- 解决CSS层叠顺序问题:
- 通过将组件渲染到DOM树的特定位置,React Portals可以避免由于CSS层叠顺序导致的布局问题。
- 这有助于实现更复杂的UI布局和样式控制。
- 提高组件的可重用性:
- 使用React Portals可以将通用的UI组件(如模态框或通知框)封装为可重用的组件。
- 这些组件可以在不同的应用中使用,并且不需要关心它们的放置位置,从而提高代码的可维护性和复用性。
- 简化DOM操作:
- React Portals提供了一种有效的方法来渲染子节点到存在于父组件DOM层次结构之外的DOM节点中。
- 这有助于打破传统父子组件层级的限制,实现更加灵活和动态的DOM操作。
- 保持组件的正常生命周期和状态管理:
- 尽管组件被渲染到了不同的DOM节点,但React Portals仍然能够保持组件的正常生命周期和状态管理。
- 这意味着可以在Portal内部使用状态、事件处理程序等React功能,从而简化事件处理和状态管理。
- 处理全局或跨层级的UI元素:
-
缺点
- 可能增加应用的复杂性:
- 虽然React Portals使得模态框和工具提示等组件的实现更简单,但同时也增加了应用的复杂性。
- 开发者需要更加小心地管理状态和事件,因为组件的渲染位置与组件的层次结构不再一致。
- 事件冒泡可能变得更加复杂:
- 在使用React Portals时,某些事件的冒泡可能会变得更加复杂。
- 由于Portals在DOM树中的位置与React树中的位置不一致,因此事件可能会在不期望的组件中触发或停止冒泡。
- 性能开销:
- 使用React Portals可能会导致额外的DOM节点,这可能在某些情况下带来性能开销。
- 虽然对于大多数应用而言,这种影响微乎其微,但在性能敏感的应用中需要考虑这一点。
- 需要额外的DOM节点:
- React Portals需要有一个真实的DOM节点作为挂载点。
- 这意味着开发者需要在应用中为Portals预留合适的DOM节点,这可能会增加一些额外的开发工作。
- 可能增加应用的复杂性:
实例:全局通知框(Notification)的实现
在这个实例中,我们将使用React Portals来实现一个全局通知框组件
。通知框通常需要在应用的任何内容之上显示
,并且可能会频繁地出现和消失
,因此它是一个很好的React Portals使用场景
。
-
创建NotificationManager组件
首先,我们创建一个NotificationManager
组件,它将负责管理通知框的显示和隐藏
。这个组件将使用React的上下文(Context)API来提供一个全局的通知框状态和方法
。// NotificationManager.jsx import React, { createContext, useState, useEffect } from 'react'; import ReactDOM from 'react-dom';const NotificationContext = createContext();export const NotificationProvider = ({ children }) => {const [notifications, setNotifications] = useState([]);// 创建一个容器用于挂载Portalconst container = document.createElement('div');document.body.appendChild(container);useEffect(() => {return () => {document.body.removeChild(container);};}, []);const addNotification = (message) => {setNotifications((prevNotifications) => [...prevNotifications,{ id: Date.now(), message },]);// 自动移除通知(模拟)setTimeout(() => {setNotifications((prevNotifications) =>prevNotifications.filter((notification) => notification.id !== Date.now()));}, 3000);};const value = { notifications, addNotification };return (<NotificationContext.Provider value={value}>{children}{ReactDOM.createPortal(<div className="notification-container">{notifications.map((notification) => (<div key={notification.id} className="notification">{notification.message}</div>))}</div>,container)}</NotificationContext.Provider>); };export const useNotifications = () => React.useContext(NotificationContext);
-
添加样式
接下来,我们为通知框添加一些基本样式。/* styles.css */ .notification-container {position: fixed;top: 20px;right: 20px;width: 300px;z-index: 1000; }.notification {padding: 10px;margin-bottom: 10px;background-color: #fff;box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);border-radius: 4px;opacity: 0;transform: translateY(20px);animation: slideIn 0.3s forwards ease-in-out; }@keyframes slideIn {to {opacity: 1;transform: translateY(0);} }
-
使用NotificationManager组件
现在,我们可以在应用的其他部分使用这个NotificationManager组件,并通过上下文API来添加通知
。// App.jsx import React from 'react'; import { NotificationProvider, useNotifications } from './NotificationManager'; import './styles.css';const NotifyButton = () => {const { addNotification } = useNotifications();const handleClick = () => {addNotification('This is a notification message!');};return <button onClick={handleClick}>Notify Me</button>; };function App() {return (<NotificationProvider><div><h1>My App</h1><NotifyButton /></div></NotificationProvider>); }export default App;
总结
-
在React 18中,我们使用React Portals来实现了一个全局通知框组件。NotificationManager组件创建了一个容器,并将其添加到document.body的末尾。然后,它使用ReactDOM.createPortal方法将通知框的内容渲染到这个容器上。这样,
通知框就可以浮在应用的其他内容之上,而不会受到组件层次结构的限制
。 -
我们还使用了React的上下文(Context)API来提供一个
全局的通知框状态和方法
,这样应用中的任何组件都可以轻松地添加通知。
值得注意的是,虽然React 18引入了并发模式和新的更新机制
,但React Portals的基本使用方式并没有改变。然而,在并发模式下,React可能会更加高效地处理Portals的更新和渲染,特别是在处理频繁出现和消失的通知框等UI元素时
。
相关文章:
React Portals 有什么用
React Portals是React提供的一种机制,它允许开发者将组件渲染到DOM树中的不同位置,而不受组件层次结构的限制。React Portals的主要用途和优势包括以下几个方面: 用途和优势 处理全局UI元素 React Portals允许将UI元素渲染到应用的根DOM之外…...
光学偏振的基础知识
前言与目录 XXX 目录 一、 二、 三、 一、总结 光的偏振 光具有三个基本特性,即波长、强度和偏振。光的波长很容易理解,以常见的可见光为例,波长范围为380~780nm。光的强度也很容易理解,一束光的强弱可以通过功率的大小来表征…...
小程序 - 计算器
小程序交互练习 - 计算器小程序 目录 计算器 功能描述 准备工作 创建项目 配置导航栏 创建utils目录 math.js文件内容 calc.js文件内容 页面内容 页面样式内容 页面脚本事件 功能截图 总结 计算器 在日常生活中,计算器是人们广泛使用的工具࿰…...
软件架构:从传统单体到现代微服务的技术演变
1.引言 在软件开发中,架构设计不仅仅是程序员的技术任务,它更是一个项目成功的关键。无论是小型应用还是大型分布式系统,软件架构都直接影响着系统的可维护性、可扩展性、性能和稳定性。理解软件架构的必要性,能够帮助开发人员做…...
CTF之密码学(rot密码)
ROT加密算法,也被称为Caesar加密,是一种简单的字母替换加密算法。以下是对ROT加密算法的详细介绍: 一、基本原理 ROT加密算法通过将字母表中的每个字母向后(或向前)移动固定的位置来加密文本。选择一个固定的偏移量&…...
linux安装nodejs管理器,并配置node、npm 软链接
一,安装nodejs管理器 注意——不同版本,可能有问题 亲测这个版本,安装后,npm正常使用——v20.10.0 二,配置软链接——快速访问——不要多些空格(会出现invalid option错误) ln -s /www/server…...
Linux 环境下 PostgreSQL 常用命令操作指南
在 Linux 系统中,PostgreSQL 配备了一系列实用命令以进行数据库操作。具体如下: 注意事项:若采用 docker 部署,需预先进入 docker 容器。 进入 docker 容器命令: docker exec -it 容器名 bash 向容器内复制本地文件命…...
Implicit style-content separation using lora
1.Introduction 图像风格化,这个任务涉及根据某些风格参考改编图像的风格,这些参考可以是基于文本或基于图像的,同时保持其内容不变,内容指的是图像的语义信息和结构,而风格通常指的是视觉特征和模式,例如颜色和纹理。这是一个有挑战的任务,因为风格和内容之间的强关联…...
网易博客旧文-----如何在WINDOWS下载安卓(android)源代码并和eclipse做关联
如何在WINDOWS下载安卓(android)源代码并和eclipse做关联 2013-02-05 17:27:16| 分类: 安卓开发 | 标签: |举报 |字号大中小 订阅 编写安卓程序时,有时想看看安卓某些类的实现,但默认情况下环境是不带的。…...
Qt入门9——绘图
基本概念 虽然Qt已经内置了很多的控件,但是不能保证现有控件就可以应对所有场景. 很多时候我们需要更强的"DIY"能力; Qt 提供了画图相关的API,可以允许我们在窗口上绘制任意的图形形状,来完成更复杂的界面设计。 绘图api核心类: 类说明QPaint…...
漫画之家系统:Spring Boot框架下的漫画版权保护
摘 要 随着信息技术和网络技术的飞速发展,人类已进入全新信息化时代,传统管理技术已无法高效,便捷地管理信息。为了迎合时代需求,优化管理效率,各种各样的管理系统应运而生,各行各业相继进入信息管理时代&a…...
K8S服务突然中断无法访问:报The node had condition: [DiskPressure]异常
一、背景 程序在运行过程中,突然无法访问,发现后台接口也无法访问;查看kuboard,发现报如下异常:The node had condition: [DiskPressure]. 继续查看磁盘使用率,发现系统盘使用率已经高达93%。问题前后呼应…...
5.11【机器学习】
先是对图像进行划分 划分完后, 顺序读取文件夹,在文件夹里顺序读取图片, 卷积层又称为滤波器,通道是说滤波器的个数,黑白通道数为1,RGB通道个数为3 在输入层,对于输入层而言,滤波…...
JavaWeb开发12
登陆拦截 会话技术 会话:用户打开浏览器,访问web服务器的资源,会话建立,直到有一方断开连接,会话结束。在一次会话中可以包含多次请求和响应 会话跟踪:一种维护浏览器状态的方法,服务器需要识…...
《乌合之众》笔记
1.集体会降智,会互相传染 2.群体是无名氏,因此没必要承担责任。约束个人的责任感消失 3.有意识人格的消失,无意识人格的得势,思想和感情因为暗示和互相传染而转向一个共同的方向,以及立刻把暗示的观念转化为行动的倾…...
[241206] X-CMD 发布 v0.4.15:env 升级,mirror 支持华为/腾讯 npm 镜像,pb-wayland 剪贴板
目录 X-CMD 发布 v0.4.15📃Changelog📦 env|pkg🪞 mirror📑 pb🎨 theme|starship|ohmyposh🤖 chat📝 man✅ 升级指南 X-CMD 发布 v0.4.15 📃Changelog 📦 env|pkg 新增…...
Vue前端开发-路由跳转及带参数跳转
在Vue 3中,由于没有实例化对象this,因此,无法通过this去访问 $route对象,而是通过导入一个名为 useRouter 的方法,执行这个方法后,返回一个路由对象,通过这个路由对象就可以获取到当前路由中的信…...
AI赋能:构建安全可信的智能电子档案库
在档案的政策与法规上,《中华人民共和国档案法》2020年修订新增,对电子档案的合法要件、地位和作用、安全管理要求和信息化系统建设等方面作出了明确规定,保障数字资源的安全保存和有效利用。 日前,国家档案局令第22号公布《电子…...
时间序列绘图1
用到的包 #时间序列预测 library(forecast) #数据可视化 library(ggplot2) #包含《Forecasting: Principles and Practice》第三版中使用的数据集和函数 library(fpp3)时间序列图 #提取1990年及以后的零售贸易职位的数据,并选择月份和就业人数 us_employment |>…...
云计算.运维.面试题
1、计算机能直接识别的语言( C )。 A、汇编语言 B、自然语言 C、机器语言 D、高级语言 2、应用软件是指( D )。 A、所有能够使用的软件 B、能被各应用单位共同使用的某种软件 C、所有计算机上都应使用的基本软件D、专门为某一应用目的而编制的软件 3、计算机的显示器是一…...
Bootstrap-HTML(三)Bootstrap5列表组全解析
Bootstrap-HTML(三)Bootstrap5列表组全解析 前言(一)HTML 列表基础回顾1.无序列表2.有序列表3.定义列表 二、无样式的有序列表和无序列表内联列表 三、Bootstrap5 列表组1.基础的列表组2.设置禁用和活动项3.链接项的列表组4.移除列…...
黑马程序员MybatisPlus/Docker相关内容
Day01 MP相关知识 1. mp配置类: 2.条件构造器: 具体的实现例子: ①QuerryWapper: ②LambdaQueryWrapper: 3.MP的自定义SQL 4.MP的Service层的实现 5.IService下的Lambda查询 原SQL语句的写法: Lambda 查询语句的…...
01_Node.js入门 (黑马)
01_Node.js入门 知识点自测 从 index.js 出发,访问到 student/data.json 的相对路径如何写? A:../public/teacher/data.json B:./public/student/data.json C:../student/data.json <details><summary>答案</sum…...
在Java中使用Apache POI导入导出Excel(六)
本文将继续介绍POI的使用,上接在Java中使用Apache POI导入导出Excel(五) 使用Apache POI组件操作Excel(六) 43、隐藏和取消隐藏行 使用 Excel,可以通过选择该行(或行)来隐藏工作表…...
黑马微服务开发与实战学习笔记_MybatisPlus_P2核心功能
系列博客目录 文章目录 系列博客目录Part1:条件构造器案例 基于QueryWrapper的查询案例 基于UpdateWrapper的查询条件构造器的用法总结 Part2:自定义SQL案例1案例2解决方案 Part3:IService接口IService接口基本用法实战案例准备工作开始基本用法实战IService的Lambda查询实战 批…...
华为云域名网站修改DNS服务器教程
修改单个域名的DNS服务器 登录域名注册控制台。 进入“域名列表”页面。 在域名列表中,单击“域名”列的待修改DNS服务器的域名。 进入域名信息页面。 图1 域名信息 在域名信息页面,单击“DNS服务器”后的“修改”,进入“修改DNS服务器”页面。 图2 修改DNS服务器 在…...
Redis 基础、Redis 应用
Redis 基础 什么是 Redis? Redis (REmote DIctionary Server)是一个基于 C 语言开发的开源 NoSQL 数据库(BSD 许可)。与传统数据库不同的是,Redis 的数据是保存在内存中的(内存数据库…...
三分钟掌握MySQL-MVCC底层原理
MVCC介绍 mvcc是mysql为了解决脏读、不可重复读等事务之间读写问题而诞生的;它替代了一些场景下的低效锁,在保证隔离性的基础上,提升了读取效率和并发性。 MVCC实现 在mysql中mvcc是基于mysql的undo log和readview来实现的。 undo log 在…...
CSS 快速上手
目录 一. CSS概念 二. CSS语法 1. 基本语法规范 2. CSS的三种引入方式 (1) 行内样式 (2) 内部样式表 (3) 外部样式表 3. CSS选择器 (1) 标签选择器 (2) 类选择器 (3) id选择器 (4) 通配符选择器 (5) 复合选择器 <1> 空格 <2> 没有空格 <3> &q…...
51c视觉~YOLO~合集4
我自己的原文哦~ https://blog.51cto.com/whaosoft/12512597 1、Yolo8 1.1、检测PCB元件 技术世界正在以惊人的速度发展,而这种转变的核心是一个革命性的工具 — 计算机视觉。它最有趣的应用之一是电子印刷电路板 (PCB) 的检测和分析。本文…...
深入浅出:PHP函数的定义与使用
文章目录 前言什么是函数定义函数语法示例 调用函数示例 参数传递按值传递示例按引用传递示例默认参数示例可变数量的参数示例 返回值示例 变量作用域全局作用域示例局部作用域示例静态作用域示例 匿名函数示例闭包示例 递归函数示例 内置函数常见内置函数示例 用户自定义函数示…...
前端调试实践
作者:效能研发部 黄泽平 前言 在日常调试问题中,相信我们很多人都是用console去排查相关的问题,虽然问题也可以排查出来,但是有时它的效率并不高。这篇文章主要讲解关于断点和一些日常调试技巧的内容,方便你在日后调…...
芯科科技突破性超低功耗Wi-Fi 6和低功耗蓝牙5.4模块加速设备部署
致力于以安全、智能无线连接技术,建立更互联世界的全球领导厂商Silicon Labs(亦称“芯科科技”,今日宣布推出SiWx917Y超低功耗Wi-Fi 6和低功耗蓝牙(Bluetooth LE)5.4模块。 作为成功的第二代无线开发平台的新产品&…...
Matlab自学笔记四十三:使用函数拆分日期时间型数据的子信息:年、月、日、时、分、秒
使用函数拆分日期时间型数据的子信息:年、月、日、时、分、秒,函数包括年year,季度quarter,月month,周week,日day,时hour,分minute,秒second,年月日ymd&#…...
【NLP高频面题 - LLM架构篇】大模型使用SwiGLU相对于ReLU有什么好处?
【NLP高频面题 - LLM架构篇】大模型使用SwiGLU相对于ReLU有什么好处? 重要性:★★★ 💯 NLP Github 项目: NLP 项目实践:fasterai/nlp-project-practice 介绍:该仓库围绕着 NLP 任务模型的设计、训练、优化…...
【Python爬虫实战】轻量级爬虫利器:DrissionPage之SessionPage与WebPage模块详解
🌈个人主页:易辰君-CSDN博客 🔥 系列专栏:https://blog.csdn.net/2401_86688088/category_12797772.html 目录 前言 一、SessionPage (一)SessionPage 模块的基本功能 (二)基本使…...
python查找大文件
完整代码,不仅会捕获错误,还会输出大于 1MB 文件的大小(以 MB 为单位),并跳过访问受限或已删除的文件。 代码 import os# 查找当前目录及子目录下大于 1MB 的文件,并输出文件大小 for root, dirs, files in os.walk(.):for name in files:...
秒懂:使用js验证hash, content hash , chunk hash的区别
一、使用js验证hash, content hash , chunk hash的区别 1、计算一般的 Hash(以简单字符串为例) 使用crypto-js库来进行哈希计算,需提前引入npm install crypto-js库。 crypto-js: 是一个JavaScript加密算法库,用于实…...
RabbitMQ消息可靠性保证机制6--可靠性分析
在使用消息中间件的过程中,难免会出现消息错误或者消息丢失等异常情况。这个时候就需要有一个良好的机制来跟踪记录消息的过程(轨迹溯源),帮助我们排查问题。 在RabbitMQ中可以使用Firehose实现消息的跟踪,Firehose可…...
【NoSQL数据库】MongoDB数据库——集合和文档的基本操作(创建、删除、更新、查询)
目录 一、MongoDB数据库原理 二、MongoDB数据库和集合基本操作(增删改查) 三、MongoDB数据库的文档基本操作(增删改) 四、学习笔记 往期文章:【NoSQL数据库】MongoDB数据库的安装与卸载-CSDN博客 一、MongoDB数据…...
IDL学习笔记(二)IDL处理卫星数据
IDL处理卫星数据 HDF文件数据集属性通用属性 常用HDF4操作函数常用的HDF5操作函数读取HDF文件的一般步骤 HDF4文件读取-----数据信息查询HDF4文件读取示例-----目标数据TIFF输出提取modis产品中数据,与某一点经纬度最接近的点有效结果,并按每行内容为日期…...
用点云信息来进行监督目标检测
🍑个人主页:Jupiter. 🚀 所属专栏:传知代码 欢迎大家点赞收藏评论😊 目录 概述问题分析Making Lift-splat work well is hard深度不准确深度过拟合不准确的BEV语义 模型总体框架显性深度监督 深度细化模块演示效果核心…...
Python编写api接口读取电商商品详情数据示例
以下是一个使用 Python 的 Flask 框架来编写一个简单的 API 接口,用于读取模拟的电商商品详情数据的示例代码。这里假设商品详情数据是存储在一个简单的字典中模拟数据库存储,实际应用中你需要连接真正的数据库(如 MySQL、MongoDB 等…...
用纯 CSS 实现网格背景
是不是在日常开发中经常遇到实现网格的需求,网格通常对网页中展示的元素能起到很好的定位和对齐作用。 这里介绍如何只通过 CSS 来实现这个需求? 使用背景图 这里我们的背景图使用 SVG 来创建,首先,创建绘出一个正方形ÿ…...
CNN+LSTM+AM研究方向初尝试
CNNLSTMAM研究方向初尝试 简单介绍 CNN CNN 的基本结构 卷积层(Convolutional Layer): 该层通过卷积操作提取输入数据的特征。卷积操作使用多个卷积核(滤波器)对输入图像进行局部感知,从而识别出边缘、纹…...
对比 LiveData 和 Flow 的实现方式
前一段忙完了鸿蒙,现在又开始 Android 开发了。由于之前公司都是都是偏传统开发方式,基本都是 Java 开发 Android 那一套。现在开始学习现代 Android 开发了。 对比 LiveData 和 Flow 的实现方式 在 Android 开发中,LiveData 和 Flow 都可以用来管理异步数据流和实现 UI 的…...
React.memo 和useMemo 的区别
React.memo 和 useMemo 都是 React 中的性能优化工具,但它们的用途和工作原理不同。以下是它们的主要区别: 1. React.memo React.memo 是一个高阶组件(HOC),用于优化组件的渲染,防止不必要的重新渲染。当组…...
视频码率到底是什么?详细说明
视频码率(Video Bitrate)是指在单位时间内(通常是每秒)传输或处理的视频数据量,用比特(bit)表示。它通常用来衡量视频文件的压缩程度和质量,码率越高,视频质量越好&#…...
CentOS7停更后,如何配置国内Yum源、镜像源
CentOS7停更后,如何配置国内Yum源、镜像源 yum介绍步骤1. 备份原有的yum源文件2. 下载国内Yum源文件3. 清除缓存并更新Yum源4. 使用国内Yum源 yum介绍 Yum(Yellowdog Updater Modified)是一个在CentOS和Red Hat Enterprise Linux(…...
黑石云|Linux-基础口令
在Linux系统中,设置和管理口令(密码)是确保系统安全性的重要环节。以下是一些关于Linux基础口令的详细解释和操作指南: 一、口令设置命令 passwd命令 功能:用于更改当前用户的密码。 使用方法:在终端中输…...