当前位置: 首页 > news >正文

深入理解CSS语法:掌握Web开发的基石

深入理解CSS语法:掌握Web开发的基石

在构建现代网页的过程中,层叠样式表(CSS)扮演着至关重要的角色。它不仅负责定义HTML元素的视觉表现,还极大地增强了Web内容的可访问性和用户体验。本文将深入探讨CSS的语法、书写位置、以及如何有效地使用CSS来优化你的网页设计。

CSS语法基础

CSS规则由选择器和一条或多条声明组成。每条声明都包含一个属性名和一个属性值,它们之间用冒号分隔,并被大括号包围。例如:

p {width: 200px;height: 200px;font-size: 12px;
}

在这个例子中,p是选择器,它选中所有段落元素,并为它们设置了宽度、高度和字体大小。

CSS的书写位置

CSS可以根据其放置的位置分为四种类型:内联式、内嵌式、外联式和导入式。

内联式

内联式是将CSS直接写在HTML标签的style属性中。这种方式虽然简单,但不利于代码的重用和维护。

<p style="width:200px;height:200px;font-size:12px;">这是一个段落。</p>

优点

  • 快速应用样式,无需额外的文件。

缺点

  • 不便于维护和复用。
  • 增加HTML文件的复杂性。
内嵌式

内嵌式是将CSS写在HTML文件的<head>部分的<style>标签内。这种方式实现了结构和样式的分离,但仍然限制在单个HTML文件中。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style>p {width: 200px;height: 200px;font-size: 12px;}</style>
</head>
<body><p>这是一个段落。</p>
</body>
</html>

优点

  • 结构与样式分离,便于维护。
  • 适用于小型项目或单个页面。

缺点

  • 无法跨多个HTML文件共享样式。
  • 当样式较多时,可能会使HTML文件变得臃肿。
外联式

外联式是将CSS写在一个单独的.css文件中,并通过<link>标签引入到HTML中。这是最常用的方式,因为它允许多个HTML文件共享同一个样式表,提高了代码的可维护性和复用性。

<!-- HTML文件 -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><link rel="stylesheet" href="styles.css">
</head>
<body><p>这是一个段落。</p>
</body>
</html>
/* styles.css文件 */
p {width: 200px;height: 200px;font-size: 12px;
}

优点

  • 高度可复用,适合大型项目。
  • 易于管理和维护。
  • 浏览器缓存机制,提高加载速度。

缺点

  • 需要额外的HTTP请求来加载外部CSS文件。
  • 对于小型项目可能显得过于复杂。
导入式

导入式是在CSS文件中通过@import语句导入另一个外部CSS文件。这种方式较少使用,因为它可能导致加载延迟。

/* main.css文件 */
@import url('styles.css');

优点

  • 可以将多个CSS文件合并成一个文件,方便管理。

缺点

  • 可能导致加载延迟,影响性能。
  • 兼容性问题,某些旧版浏览器不支持。

CSS常用样式属性

文字颜色

通过color属性设置,支持多种颜色值表示方式,如颜色名、RGB模式和十六进制等。

p {color: red; /* 使用颜色名 */color: #ff0000; /* 使用十六进制 */color: rgb(255, 0, 0); /* 使用RGB模式 */
}

优点

  • 灵活多样的颜色表示方式。
  • 易于理解和使用。

缺点

  • 颜色名在不同浏览器中的表现可能略有不同。
  • 十六进制和RGB模式可能不如颜色名直观。
字体

通过font-family属性设置,可以指定多个字体名称,浏览器会按顺序尝试加载直到找到可用的字体。

p {font-family: "Arial", "Helvetica", sans-serif; /* 优先使用Arial,其次Helvetica,最后sans-serif */
}

优点

  • 提供了多种字体选择,增加了文本显示的灵活性。
  • 可以指定备用字体,确保在主字体不可用时有替代方案。

缺点

  • 如果指定的字体不可用,浏览器会回退到下一个字体,可能导致显示效果不一致。
  • 需要确保用户设备上安装了指定的字体。
字号

通过font-size属性设置,推荐使用相对长度单位,如em或rem,以提高响应式设计的灵活性。

p {font-size: 1em; /* 相对于父元素的字体大小 */font-size: 1rem; /* 相对于根元素的字体大小 */
}

优点

  • 使用相对单位,使得布局更加灵活和响应式。
  • 易于调整整体字体大小而不影响其他尺寸。

缺点

  • 需要对相对单位有一定的理解,否则可能导致意外的布局问题。
  • 在某些情况下,可能需要额外的计算来确定最终的字体大小。
字体风格

通过font-style属性设置,常见的值有normal、italic和oblique。

p {font-style: normal; /* 正常字体 */font-style: italic; /* 斜体 */font-style: oblique; /* 倾斜字体 */
}

优点

  • 提供了多种字体风格选择,满足不同的设计需求。
  • 易于实现文本的特殊效果。

缺点

  • 并非所有字体都支持斜体或倾斜效果。
  • 在某些情况下,斜体和倾斜效果可能难以区分。
字体粗细

通过font-weight属性设置,常用的值包括normal和bold,以及数值范围从100到900。

p {font-weight: normal; /* 正常粗细 */font-weight: bold; /* 加粗 */font-weight: 700; /* 数值表示的粗细 */
}

优点

  • 提供了多种字体粗细选择,满足不同的设计需求。
  • 易于实现文本的强调效果。

缺点

  • 数值表示的粗细在不同浏览器中的表现可能略有不同。
  • 需要根据设计需求选择合适的粗细值。

结论

掌握CSS的基本语法和最佳实践对于任何希望成为前端开发者的人来说都是必要的。通过合理地组织和使用CSS,你可以创建出既美观又易于维护的网站。记住,良好的CSS实践不仅能提升网站的视觉效果,还能改善用户的浏览体验。

相关文章:

深入理解CSS语法:掌握Web开发的基石

深入理解CSS语法&#xff1a;掌握Web开发的基石 在构建现代网页的过程中&#xff0c;层叠样式表&#xff08;CSS&#xff09;扮演着至关重要的角色。它不仅负责定义HTML元素的视觉表现&#xff0c;还极大地增强了Web内容的可访问性和用户体验。本文将深入探讨CSS的语法、书写位…...

基于python爬虫的智慧人才数据分析系统

废话不多说&#xff0c;先看效果图 更多效果图可私信我获取 源码分享 import os import sysdef main():"""Run administrative tasks."""os.environ.setdefault(DJANGO_SETTINGS_MODULE, 智慧人才数据分析系统.settings)try:from django.core.m…...

创建maven私人创库nexus

1.到官网下载nexus-3.74.0-05-unix.tar.gz包&#xff0c;若下载慢可以去这里下载地址 2.上传到liunx的根目录opt文件中&#xff0c;然后解压命令&#xff1a; tar -xzf nexus-3.74.0-05-unix.tar.gz 3.解压后会得到两个文件夹nexus-3.74.0-05 和 sonatype-work &#xff0c;…...

眼部按摩仪WT2605音频蓝牙语音芯片方案 单芯片实现语音提示及控制/手机无线音频传输功能

随着科技的快速发展&#xff0c;人们的生活方式也在不断改变&#xff0c;智能化、便捷化的产品逐渐成为市场的主流。眼部按摩仪作为一种结合了现代科技与健康生活理念的产品&#xff0c;受到了广大消费者的青睐。而在众多眼部按摩仪中&#xff0c;采用WT2605音频蓝牙芯片的方案…...

【面试题】2025年百度校招Java后端面试题

文章目录 前言一、网络IO1、服务器处理并发请求有哪几种方式&#xff1f;2、说一下select&#xff0c;poll&#xff0c;epoll的区别&#xff1f;3、Java 有一种现代的处理方式&#xff0c;属于异步I/O&#xff0c;是什么&#xff1f;redis&#xff0c;nginx&#xff0c;netty 是…...

Java面向对象. 多态

目录 java多态是什么东西&#xff1f;首先要理解什么是多态 Java多态指同一行为具有多个不同表现形式。如父类引用指向子类对象&#xff0c;调用重写方法时呈现不同结果。 1.多态的概念 一、多态的基本概念 二、多态的实现方式 接口实现 三、多态的好处 提高代码的可扩展…...

Vue 项目中有哪些内存泄漏的场景,以及预防内存泄漏技巧

前言 即便是功能强大的 Vue.js 也无法完全避免内存泄漏的问题&#xff0c;内存泄漏不仅会影响应用的性能&#xff0c;还可能导致浏览器崩溃。因此&#xff0c;识别和解决 Vue 项目中的内存泄漏问题是确保项目稳定性和性能的关键。 本文将通俗易懂地介绍 Vue 项目中常见的内存泄…...

MySQL Inception工具

MySQL Inception是一个强大的数据库变更管理和审计工具&#xff0c;主要用于审核、执行、备份以及回滚数据库操作。它的工作模式和MySQL完全相同&#xff0c;可以直接使用MySQL客户端来连接&#xff0c;但不需要验证权限。Inception相对于应用程序&#xff08;上层审核流程系统…...

Linux(Centos7)---安装nginx(很简单)

安装 sudo yum install nginx -y开机启动与开启服务 sudo systemctl enable nginx sudo systemctl start nginx...

多数元素

多数元素 给定一个大小为 n 的数组 nums &#xff0c;返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。 你可以假设数组是非空的&#xff0c;并且给定的数组总是存在多数元素。 示例 1&#xff1a; 输入&#xff1a;nums [3,2,3] 输出&#xff…...

vim编辑器的一些配置和快捷键

记录vim编辑器的一些配置和快捷键&#xff0c;边学边用&#xff1a; yy 复制dd 删除p&#xff1a;粘贴ctrly 取消撤销u&#xff1a;撤销:w 写入:q 退出a/i 插入O: 上方插入一个空行o&#xff1a;下方插入一个空行:e 打开文件编辑 其他配置&#xff1a; 上移一行和下移一行&a…...

SeggisV1.0 遥感影像分割软件【源代码】讲解

在此基础上进行二次开发&#xff0c;开发自己的软件&#xff0c;例如&#xff1a;【1】无人机及个人私有影像识别【2】离线使用【3】变化监测模型集成【4】个人私有分割模型集成等等&#xff0c;不管是您用来个人学习还是公司研发需求&#xff0c;都相当合适&#xff0c;包您满…...

14 —— Webpack解析别名

import {checkPhone, checkCode} from ../src/utils/check.js 这么使用相对路径不安全 —— 在webpack.config.js中配置解析别名来代表src绝对路径...

《C++ Primer Plus》学习笔记|第8章 函数探幽 (24-11-30更新)

文章目录 8.1 内联函数8.2 引用变量8.2.1 创建引用变量8.2.2 将引用用作函数参数8.2.3 引用的属性和特别之处特点1&#xff1a;在计算过程中&#xff0c;传入的形参的值也被改变了。特点2&#xff1a;使用引用的函数参数只接受变量&#xff0c;而不接受变量与数值的运算左值引用…...

vscode的项目给gitlab上传

目录 一.创建gitlab帐号 二.在gitlab创建项目仓库 三.Windows电脑安装Git 四.vscode项目git上传 一.创建gitlab帐号 二.在gitlab创建项目仓库 图来自:Git-Gitlab中如何创建项目、创建Repository、以及如何删除项目_gitlab新建项目-CSDN博客&#xff09; 三.Windows电脑安…...

【JVM什么时候触发YoungGC和FullGC】

YoungGC 年轻代Eden区满&#xff0c;就会触发YoungGC FullGC 老年代空间不足 经过多次GC后的大年龄对象会被放进老年代&#xff0c;或创建的大对象会直接在老年代分配&#xff0c;此时若老年代空间不足&#xff0c;就会触发FullGC。空间分配担保失败 触发YoungGC的时候会进行…...

Mybatis-批量删除用户

目录 题目&#xff1a; 1、创建Maven项目&#xff0c;在pom.xml中添加相关依赖 2、创建db.properties配置数据库信息 3、在resources下创建mybatis-config.xml核心配置文件 易错点&#xff1a; 4、在java中创建User.java&#xff0c;在java/com/haust/pojo下 5、在java中…...

Python的秘密基地--[章节2]Python核心数据结构

第2章&#xff1a;Python核心数据结构 Python中的数据结构提供了强大的工具来存储和操作数据。理解这些数据结构是Python编程的基础。 2.1 列表&#xff08;List&#xff09; 2.1.1 什么是列表 列表是一种有序的可变序列&#xff0c;用于存储一组数据。它支持多种类型的数据…...

TYUT设计模式精华版

七大原则 单一职责原则 职责要单一不能将太多的职责放在一个类中 开闭原则 软件实体对扩展是开放的&#xff0c;但对修改是关闭的 里氏代换原则 一个可以接受基类对象的地方必然可以接受子类 依赖倒转原则 要针对抽象层编程&#xff0c;而不要针对具体类编程 接口隔离原则 …...

责任链模式

07-责任链模式 1 导读 1.1 定义 包含了一些命令对象和一系列处理对象。每个处理对象决定它能处理哪些命令对象&#xff0c;它也知道如何将它不能处理的命令对象传递给该链中的下一个处理对象。 该模式还描述了往该处理链的末尾添加新的处理对象的方法。 精简定义&#xff1a;为…...

2024.11.29(单链表)

思维导图 声明文件 #ifndef __LINKLIST_H__ #define __LINKLIST_H__#include <myhead.h>typedef char datatype; //数据元素类型 //定义节点类型 typedef struct Node {union{int len; //头节点数据域datatype data; //普通节点数据域};struct Node *next; //指针域…...

用Python做数据分析环境搭建及工具使用(Jupyter)

目录 一、Anaconda下载、安装 二、Jupyter 打开 三、Jupyter 常用快捷键 3.1 创建控制台 3.2 命令行模式下的快捷键 3.3 运行模式下快捷键 3.4 代码模式和笔记模式 3.5 编写Python代码 一、Anaconda下载、安装 【最新最全】Anaconda安装python环境_anaconda配置python…...

洛谷P1443 马的遍历

简单的bfs 题目链接 P1443 马的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题目描述 有一个 nm 的棋盘&#xff0c;在某个点(x,y) 上有一个马&#xff0c;要求你计算出马到达棋盘上任意一个点最少要走几步。 输入格式 输入只有一行四个整数&#xff0c;分别为 n…...

实现一个Vue自定义指令

在 Vue 中&#xff0c;自定义指令允许你为 DOM 元素添加特定的行为或功能。下面是一个实现 Vue 自定义指令的简单示例&#xff0c;展示了如何创建一个指令&#xff0c;使得元素在鼠标悬停时改变背景色。 1. 创建自定义指令 在 Vue 2.x 中&#xff0c;你可以在 Vue.directive …...

【已解决】git push需要输入用户名和密码问题

解决方法&#xff1a; 1&#xff09;查看使用的clone方式&#xff1a; git remote -v 2&#xff09;若为HTTPS&#xff0c;删除原clone方式: git remote rm origin 3&#xff09;添加新的clone方式&#xff1a; git remote add origin gitgithub.com:zludon/git_test.git …...

什么是内存对齐?为什么需要内存对齐?

1. 什么是内存对齐 内存对齐是指将数据存储在内存中时&#xff0c;按照一定的规则让数据排列在规定的地址上。具体来说&#xff0c;每个成员变量会按照其自身所占用的字节数对齐&#xff0c;内存首地址为对齐周期的倍数&#xff0c;而对齐周期指的是数据类型的大小。例如&…...

数据库操作、锁特性

1. DML、DDL和DQL是数据库操作语言的三种主要类型 1.1 DML&#xff08;Data Manipulation Language&#xff09;数据操纵语言 DML是用于检索、插入、更新和删除数据库中数据的SQL语句。 主要的DML语句包括&#xff1a; SELECT&#xff1a;用于查询数据库中的数据。 INSERT&a…...

xiaolin coding 图解网络笔记——TCP篇

1. TCP 头格式有哪些&#xff1f; 序列号&#xff1a;在建立连接时由计算机生成的随机数作为其初始值&#xff0c;通过 SYN 包传给接收端主机&#xff0c;每发送一次数据&#xff0c;就【累加】一次该【数据字节数】的大小。用来解决网络包乱序问题。 确认应答号&#xff1a;指…...

基于大数据python 豆果美食推荐数据可视化系统(源码+LW+部署讲解+数据库+ppt)

&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 很对人不知道选题怎么选 不清楚自己适合做哪块内容 都可以免费来问我 避免后期給自己答辩找麻烦 增加难度&#xff08;部分学校只有一次答辩机会 没弄好就延迟…...

ElasticSearch通过es-head插件安装可视化及相关问题

1.es-head下载地址 GitHub - mobz/elasticsearch-head: A web front end for an elastic search cluster 2.启动 建议使用vscode启动&#xff0c;并安装好node.js环境 npm installnpm run start 通过http://localhost:9100就可以看到本地添加的es库 3.相关问题 3.1跨域问…...

JVM系列之OOM观测准备

OOM, 全称 “Out Of Memory”&#xff0c;即内存用完的意思。JVM 因为没有足够的内存来为对象分配空间并且垃圾回收器也已经没有空间可回收时&#xff08;可分配内存大于需要分配的内存&#xff09;, 就会抛出 java.lang.OutOfMemoryError。在实际的生产应用中&#xff0c;一旦…...

基于Java Springboot Vue3图书管理系统

一、作品包含 源码数据库设计文档万字全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue3、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA 数据库&#x…...

解析生成对抗网络(GAN):原理与应用

目录 一、引言 二、生成对抗网络原理 &#xff08;一&#xff09;基本架构 &#xff08;二&#xff09;训练过程 三、生成对抗网络的应用 &#xff08;一&#xff09;图像生成 无条件图像生成&#xff1a; &#xff08;二&#xff09;数据增强 &#xff08;三&#xff…...

torch.maximum函数介绍

torch.maximum 函数介绍 定义&#xff1a;torch.maximum(input, other) 返回两个张量的逐元素最大值。 输入参数&#xff1a; input: 张量&#xff0c;表示第一个输入。other: 张量或标量&#xff0c;表示第二个输入。若为张量&#xff0c;其形状需要能与 input 广播。输出&a…...

Git | 理解团队合作中Git分支的合并操作

合并操作 团队合作中Git分支的合并操作分支合并过程1.创建feature/A分支的过程2. 创建分支feature/A-COPY3.合并分支查看代码是否改变 团队合作中Git分支的合并操作 需求 假设团队项目中的主分支是main,团队成员A基于主分支main创建了feature/A&#xff0c;而我又在团队成员A创…...

源代码定制编译:构建理想的库 以curl为例

文章目录 源代码curl开发环境下载地址制定理想的库初级进阶如何知道选项名称交叉编译交叉编译工具链配置编译环境设置目标架构库和头文件路径编译代码 源代码 我们在日常中会接触到比较多第三方库&#xff0c;比如 网络库相关&#xff1a; libevent、mongoose、curl图形界面&…...

服务熔断-熔断器设计

文章目录 服务为什么需要熔断熔断器设计思想熔断器代码实现 服务为什么需要熔断 对于服务端采用的保护机制为服务限流。 对于服务调用端是否存在保护机制&#xff1f; 假如要发布一个服务 B&#xff0c;而服务 B 又依赖服务 C&#xff0c;当一个服务 A 来调用服务 B 时&#x…...

生产环境中:Flume 与 Prometheus 集成

在生产环境中&#xff0c;将 Apache Flume 与 Prometheus 集成的过程&#xff0c;需要借助 JMX Exporter 或 HTTP Exporter 来将 Flume 的监控数据转换为 Prometheus 格式。以下是详细的实现方法&#xff0c;连同原理和原因进行逐步解释&#xff0c;让刚接触的初学者也能完成集…...

深度解析MySQL的刷脏机制

前言 今天天气挺好,看大家对MySQL系列这么感兴趣,继续来聊聊MySQL,在MySQL的InnoDB中Buffer Pool和LSN关系紧密相连,尤其在脏页管理和刷新过程中起着至关重要的作用。理解LSN如何同Buffer Pool协同工作,有助于深入掌握 MySQL 的写入优化机制及数据一致性保证。 Buffer P…...

Java NIO 全面详解:初学者入门指南

除了前一篇文章讲的传统的 java.io 模块&#xff0c;Java 还提供了更现代化、更高效的非阻塞 IO 模块&#xff0c;即 java.nio&#xff08;New IO&#xff09;。java.nio 引入了面向缓冲区&#xff08;Buffer&#xff09;的数据处理方式&#xff0c;以及多路复用器&#xff08;…...

优化 Conda 下载速度:详细的代理配置和网络管理策略

优化 Conda 下载速度&#xff1a;详细的代理配置和网络管理策略 为了彻底解决使用 Conda 下载 PyTorch 时遇到的速度问题&#xff0c;并确保下载过程稳定可靠&#xff0c;这需要一个详细、综合的技术方案。让我们更深入地分析问题原因&#xff0c;然后详尽地解释采取的解决策略…...

蓝牙MCU单片机8k高回报率无线应用

随着高端无线产品性能大幅提升&#xff0c;相比常规蓝牙133Hz回报率&#xff0c;8kHz回报率作为市场最高标准&#xff0c;每秒上传8000个数据包。以鼠标为例&#xff0c;位置每秒更新8000次&#xff0c;刷新率较常规蓝牙提升了60倍&#xff0c;超低延迟、极速响应&#xff0c;已…...

Java抛出自定义运行运行

1.重新生成异常的.java文件 Empty&#xff1a;空 Exception&#xff1a;异常 加起来就是 空指针异常的文件 2.打上extends 运行的异常&#xff08;异常的类型&#xff09; 3.点击ctrlo&#xff0c;选着这两个快捷重写 4.在需要抛出异常的地方写上&#xff1a;th…...

JVM 性能调优 -- JVM常用调优工具【jps、jstack、jmap、jstats 命令】

前言&#xff1a; 前面我们分析怎么去预估系统资源&#xff0c;怎么去设置 JVM 参数以及怎么去看 GC 日志&#xff0c;本篇我们分享一些常用的 JVM 调优工具&#xff0c;我们在进行 JVM 调优的时候&#xff0c;通常需要借助一些工具来对系统的进行相关分析&#xff0c;从而确定…...

python+django自动化部署日志采用‌WebSocket前端实时展示

一、开发环境搭建和配置 # channels是一个用于在Django中实现WebSocket、HTTP/2和其他异步协议的库。 pip install channels#channels-redis是一个用于在Django Channels中使用Redis作为后台存储的库。它可以用于处理#WebSocket连接的持久化和消息传递。 pip install channels…...

【Flink-scala】DataStream编程模型之窗口计算-触发器-驱逐器

DataStream API编程模型 1.【Flink-Scala】DataStream编程模型之数据源、数据转换、数据输出 2.【Flink-scala】DataStream编程模型之 窗口的划分-时间概念-窗口计算程序 文章目录 DataStream API编程模型前言1.触发器1.1 代码示例 2.驱逐器2.1 代码示例 总结 前言 本小节我想…...

毕昇入门学习

schemas.py 概述 这段代码主要定义了一系列基于 Pydantic 的数据模型&#xff08;BaseModel&#xff09;&#xff0c;用于数据验证和序列化&#xff0c;通常用于构建 API&#xff08;如使用 FastAPI&#xff09;。这些模型涵盖了用户认证、聊天消息、知识库管理、模型配置等多…...

实时数据开发|Flink实现数据输出--DataSinks操作

哇哦&#xff0c;又是快乐周五&#xff01;今天主管又又又请我们喝奶茶了&#xff0c;是乐乐茶的草莓新品。甜甜的草莓配上糯叽叽的麻薯&#xff0c;喝完好满足。这应该不是什么加班信号吧哈哈哈&#xff0c;不加不加周五要回家。 前几天被不同的bug缠身&#xff0c;今天终于正…...

详解网络代理模式:规则、全局与直连的应用与配置

“详解网络代理模式&#xff1a;规则、全局与直连的应用与配置” 当然&#xff0c;为了提供更深入的理解&#xff0c;让我们对每种代理模式进行更详尽的探讨&#xff0c;包括它们的内部工作机制、具体使用场景以及在实际应用中的优势和局限。 规则模式&#xff08;Rule-based…...

Nacos部署和使用(服务注册与发现、配置中心)

1. docker部署nacos 参考&#xff1a; docker安装nacos-CSDN博客 2.注册中心原理 在微服务远程调用的过程中&#xff0c;包括两个角色&#xff1a; 服务提供者&#xff1a;提供接口供其它微服务访问&#xff0c;比如 A-service服务消费者&#xff1a;调用其它微服务提供的…...