杏仁海棠花饼的学习日记第十四天CSS

news2025/6/3 12:49:09

一,前言

第二天,今天看CSS。

二,CSS简介及导入方式

CSS简介

CSS(层叠样式表,Cascading Style Sheets)是一种用于描述 HTML 或 XML(包括 SVG、XHTML 等)文档呈现效果的样式语言。它通过定义元素的外观和布局,使网页内容更加美观、一致且易于阅读。下面我将从多个方面对 CSS 进行详细介绍。

导入方式

1. 外部样式表(推荐)

通过<link>标签引入外部 CSS 文件,是最常用的导入方式。

 <link rel="stylesheet" href="./CSS/style.css">

优点

  • 代码分离,提高可维护性
  • 支持浏览器缓存,提升加载速度
  • 多页面共享,减少代码重复

适用场景

  • 网站整体样式
  • 多页面共享的通用样式
  • 需要缓存的大型项目

2. 内部样式表

在 HTML 文档的<head>部分使用<style>标签定义 CSS。

<style>
    .internal-style {
        background-color: #e6f7ff;
        padding: 10px;
    }
</style>

优点

  • 无需额外 HTTP 请求
  • 适用于单页应用的特殊样式

缺点

  • 无法缓存,影响性能
  • 代码无法在多页面共享

适用场景

  • 仅当前页面使用的特殊样式
  • 小型单页应用

3. @import 规则

在 CSS 文件或<style>标签中使用@import导入其他 CSS 文件。

@import url("additional-styles.css");
@import url("https://fonts.googleapis.com/css2?family=Inter");

优点

  • 支持模块化 CSS
  • 适合导入外部资源(如字体)

缺点

  • 加载顺序问题(后导入的可能覆盖前面的)
  • 性能较差(串行加载)

适用场景

  • 模块化 CSS 结构
  • 导入外部字体或第三方样式库

4. 内联样式

直接在 HTML 元素的style属性中定义样式。

<div style="background-color: #fff2e8; padding: 10px;">
    内联样式内容
</div>

优点

  • 优先级最高,可覆盖其他样式
  • 适合 JavaScript 动态修改样式

缺点

  • 代码难以维护
  • 无法复用
  • 影响 HTML 结构与 CSS 分离原则

适用场景

  • 需要立即生效的特殊样式
  • JavaScript 动态生成的样式

5.优先级

内联样式>内部样式表>外部样式表

6.最佳实践建议

  • 优先使用外部样式表:对于大多数项目,这是最推荐的方式
  • 谨慎使用内联样式:仅在必要时使用,避免滥用
  • 避免过度使用 @import:除非必要,否则使用<link>代替
  • 保持 CSS 模块化:将样式按功能或组件拆分到不同文件
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS导入方式</title>
    <link rel="stylesheet" href="./CSS/style.css">
    <style>
        p{
            color: red;
            font-size: 16px;
        }
    </style>
</head>
<body>
    <h1 style="color: green;">你好</h1>
    <p>你好</p>
    <h3>你好</h3>
    
</body>
</html>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

三,CSS语法

1.选择器

选择器用于选择 HTML 文档中的元素,CSS 提供了多种类型的选择器:

1. 元素选择器

选择 HTML 元素类型:

/* 选择所有段落元素 */
p {
    color: red;
}

/* 选择所有标题元素 */
h1, h2, h3 {
    font-family: Arial;
}
2. 类选择器

选择具有特定class属性的元素:

/* 选择所有class="highlight"的元素 */
.highlight {
    background-color: yellow;
}

/* 选择所有class="btn"的元素 */
.btn {
    padding: 10px 20px;
}
3. ID 选择器

选择具有特定id属性的元素:

/* 选择id="main-header"的元素 */
#main-header {
    border-bottom: 2px solid #ccc;
}
4.通用选择器
 /* 通用选择器 */
        *{
            font-family: kaiti;
        }      
5.子元素选择器
6.后代选择器
  /* 子元素选择器 */
        .father .son{
            font-size: large;
        }
        /* 后代选择器 */
        .father .grandson{
            font-size: small;
        }
<div class="father">
    <p class="son">这是一个子元素选择器实例</p>
    <div>
        <p class="grandson">这是一个后代选择器实例</p>
    </div>
 </div>
7.相邻兄弟选择器
 /* 相邻兄弟选择器 */
        h3 + p{
            color:blue;
        }
<p>祝大家天天开心</p>
 <h3>这是一个相邻兄弟选择器实例</h3>
 <p>平平安安</p>
8. 伪类选择器

选择处于特定状态的元素:

/* 选择鼠标悬停的链接 */
a:hover {
    text-decoration: underline;
}

/* 选择第一个子元素 */
li:first-child {
    font-weight: bold;
}

/* 选择偶数行的表格行 */
tr:nth-child(even) {
    background-color: #f2f2f2;
}
9. 伪元素选择器

选择元素的特定部分:

/* 在每个段落前添加内容 */
p::before {
    content: "» ";
    color: red;
}

/* 选择文本的第一行 */
p::first-line {
    font-weight: bold;
}
10. 组合选择器

组合多个选择器以创建更精确的选择:

/* 后代选择器:选择article内的所有段落 */
article p {
    margin-bottom: 15px;
}

/* 子元素选择器:选择直接子元素 */
ul > li {
    list-style-type: square;
}

/* 相邻兄弟选择器:选择紧跟在h2后的p */
h2 + p {
    font-style: italic;
}

/* 通用兄弟选择器:选择h2后的所有p */
h2 ~ p {
    color: #666;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>选择器</title>
    <style>
        /* 元素选择器 */
        h2{
            color: red;
        }
        /* 类选择器 */
        .red{
            color: red;
        }
        /* ID选择器 */
        #red{
            color: red;
        }
        /* 通用选择器 */
        *{
            font-family: kaiti;
        }
        /* 子元素选择器 */
        .father .son{
            font-size: large;
        }
        /* 后代选择器 */
        .father .grandson{
            font-size: small;
        }
        /* 相邻兄弟选择器 */
        h3 + p{
            color:blue;
        }
        /* 伪类选择器 */
        #element:hover{
            background-color: pink;
        }
        /* 伪元素选择器 在选择的元素前后插入虚拟的内容*/
        h3::before{
            content: "Hello ";
            color: red;
        }
               p ::after{
            content: " World";
        }
    </style>
</head>
<body>
    <h1>不同类型的CSS选择器</h1>
 <h2>这是一个元素选择器实例</h2>
 <h3 class="red">这是一个类选择器实例</h3>
 <h4 id ="red" >这是一个ID选择器实例</h4>
 <div class="father">
    <p class="son">这是一个子元素选择器实例</p>
    <div>
        <p class="grandson">这是一个后代选择器实例</p>
    </div>
 </div>
 <p>祝大家天天开心</p>
 <h3>这是一个相邻兄弟选择器实例</h3>
 <p>平平安安</p>
<h3 id="element">这是一个伪类选择器实例</h3>
</body>
</html>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

四,CSS属性

CSS属性有上百个,并不需要全部学习。学一点常用的就好了剩下的要么重复要么使用频率很低。

CSS属性可以在官网菜鸟教程等查到。

属性是用于控制 HTML 元素外观和格式的指令,在前面也学了一些像字体颜色等属性。

一、文本属性

控制文本的字体、大小、颜色、对齐方式等。

/* 文本样式示例 */
p {
  color: #333; /* 文本颜色 */
  font-family: Arial, sans-serif; /* 字体族 */
  font-size: 16px; /* 字体大小 */
  font-weight: bold; /* 字体粗细 */
  text-align: center; /* 文本对齐 */
  text-decoration: underline; /* 文本装饰 */
  line-height: 1.5; /* 行高 */
  letter-spacing: 1px; /* 字符间距 */
}

二、盒模型属性

控制元素的宽度、高度、内边距、外边距和边框。

/* 盒模型示例 */
div {
  width: 300px; /* 宽度 */
  height: 200px; /* 高度 */
  padding: 20px; /* 内边距 */
  margin: 10px; /* 外边距 */
  border: 1px solid #ccc; /* 边框 */
  box-sizing: border-box; /* 盒模型计算方式 */
}

三、背景属性

控制元素的背景颜色、图片和位置。

/* 背景示例 */
body {
  background-color: #f5f5f5; /* 背景颜色 */
  background-image: url('bg.jpg'); /* 背景图片 */
  background-repeat: no-repeat; /* 是否重复 */
  background-position: center; /* 背景位置 */
  background-size: cover; /* 背景大小 */
}

四、定位属性

控制元素在页面中的定位方式。

/* 定位示例 */
.parent {
  position: relative; /* 相对定位 */
}

.child {
  position: absolute; /* 绝对定位 */
  top: 10px; /* 距离顶部 */
  right: 10px; /* 距离右侧 */
  z-index: 1; /* 层级顺序 */
}

.fixed {
  position: fixed; /* 固定定位 */
  bottom: 0; /* 固定在底部 */
}

五,复合属性

复合属性(Shorthand Properties)是 CSS 中用于同时设置多个相关属性的简写方式,能简化代码并提高可读性。

font

  • 功能:设置字体的样式、大小、行高、粗细和字体系列。
font: italic bold 16px/1.5 Arial, sans-serif;

/* 等价于 */
font-style: italic;
font-weight: bold;
font-size: 16px;
line-height: 1.5;
font-family: Arial, sans-serif;

1. marginpadding

  • 功能:设置元素的外边距和内边距。
  • 值顺序:上、右、下、左(顺时针)其他的相似的也是按照此顺序
/* 单值:四边相同 */
margin: 10px;

/* 双值:上下 / 左右 */
margin: 10px 20px;

/* 三值:上 / 左右 / 下 */
margin: 10px 20px 30px;

/* 四值:上 / 右 / 下 / 左 */
margin: 10px 20px 30px 40px;

五、CSS元素分类

CSS 元素分类:块级元素、行内元素、行内块元素

在 CSS 中,HTML 元素根据其默认的显示行为(display属性)可分为三大类:块级元素行内元素行内块元素

一、块级元素

特点
  • 独占一行:无论内容多少,都会在页面中单独占据一行。
  • 可设置宽度和高度:默认宽度为父元素的 100%,但可以通过width属性调整。
  • 可包含其他元素:可以包含块级元素和行内元素。
  • 支持盒模型属性:如marginpaddingborder等。
常见块级元素
<div><p><h1>~<h6><ul><li><form><header><footer>

二、行内元素

特点
  • 不换行:多个行内元素会在同一行显示,直到空间不足。
  • 宽度和高度由内容决定:无法通过widthheight属性设置。
  • 仅包含行内元素:不能包含块级元素。
  • 盒模型限制:水平方向的marginpadding有效,但垂直方向的margin无效,padding会显示但不影响布局。
常见行内元素
<a><span><img><input><label><select><textarea>、<b

三、行内块元素

特点
  • 不换行:多个行内块元素会在同一行显示。
  • 可设置宽度和高度:可以通过widthheight属性调整。
  • 支持盒模型属性:水平和垂直方向的marginpaddingborder均有效。
  • 元素间有间隙:由于 HTML 中的换行符、空格等会导致元素间出现间隙(约 4px)。
常见行内块元素
<img><input><button><select><textarea>

四、转换元素类型

可以通过display属性修改元素的类型:

/* 转换为块级元素 */
span {
  display: block;
}

/* 转换为行内元素 */
div {
  display: inline;
}

/* 转换为行内块元素 */
p {
  display: inline-block;
}

五、盒子模型

CSS 盒子模型是网页布局的核心概念,它描述了元素在页面中所占空间的计算方式。理解盒子模型对于精确控制元素大小、间距和布局至关重要。

一、盒子模型的组成部分

一个元素在页面中所占的空间由以下部分组成(从内到外):

  1. 内容区(Content)
    • 元素实际包含的文本、图片等内容。
    • 通过 widthheight 属性设置。
  2. 内边距(Padding)
    • 内容区与边框之间的距离。
    • 通过 padding-toppadding-rightpadding-bottompadding-left 或简写属性 padding 设置。
  3. 边框(Border)
    • 围绕内容区和内边距的线条。
    • 通过 border-widthborder-styleborder-color 或简写属性 border 设置。
  4. 外边距(Margin)
    • 元素与其他元素之间的距离。
    • 通过 margin-topmargin-rightmargin-bottommargin-left 或简写属性 margin 设置。

二、盒子模型的计算方式

元素的总宽度 = width + padding-left + padding-right + border-left-width + border-right-width
元素的总高度 = height + padding-top + padding-bottom + border-top-width + border-bottom-width

注意:默认情况下,widthheight 仅包含内容区,不包含内边距、边框和外边距。

三、示例代码

.box {
  width: 300px;        /* 内容区宽度 */
  height: 200px;       /* 内容区高度 */
  padding: 20px;       /* 内边距:上下左右均为20px */
  border: 5px solid red; /* 边框:宽度5px,实线,红色 */
  margin: 30px;        /* 外边距:上下左右均为30px */
}

/* 总宽度 = 300 + 20*2 + 5*2 + 30*2 = 410px */
/* 总高度 = 200 + 20*2 + 5*2 + 30*2 = 310px */

六,浮动

浮动`属性用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘,这样即
可使得元素进行浮动

注意:浮动是相对于父元素浮动,只会在父元素的内部移动

语法:

选择器{
float: left/right/none;
}

浮动没有缝隙

浮动三大特性

1.脱标:脱离标准流。
2.一行显示,顶部对齐
3.具备行内块元素特性

属性

  • left:元素向左浮动。
  • right:元素向右浮动。
  • none(默认值):元素不浮动。
  • inherit:继承父元素的浮动值。

控制元素的浮动方向和清除浮动。

/* 向左浮动 */
.float-left {
  float: left;
  margin-right: 20px;
}

/* 向右浮动 */
.float-right {
  float: right;
  margin-left: 20px;
}

/* 清除浮动两种方法 还有别的方法这两种最简单*/
.clear {
  clear: both;
}
.clearfix::after {
  content: "";
  display: table;
  clear: both; /* 清除浮动 */
}

七,定位

CSS 定位是控制元素在页面中位置的核心机制。通过position属性,可以精确控制元素的位置、层级和布局方式。

**一、定位方式:

  • 相对定位:相对于元素在文档流中的正常位置进行定位。
  • 绝对定位:相对于其最近的已定位祖先元素进行定位,不占据文档流。
  • 固定定位:相对于浏览器窗口进行定位。不占据文档流,固定在屏幕上的位置,不随滚动而移动
1. position属性的取值
  • static(默认值):元素按正常文档流排列,topleft等属性无效。
  • relative:相对定位,相对于元素的正常位置偏移。
  • absolute:绝对定位,相对于最近的已定位祖先元素(position≠static)。
  • fixed:固定定位,相对于浏览器窗口,滚动时位置不变。
  • sticky:粘性定位,在滚动时固定在某个位置,直到滚动到父元素边界。
2. 偏移属性
  • toprightbottomleft:控制元素的偏移位置。
  • z-index:控制元素的层级顺序,值越大越靠前。

二、相对定位(Relative)

特点
  • 元素仍占据原文档流位置。
  • 相对于正常位置进行偏移。
  • 不会影响其他元素的布局。
示例
.relative {
  position: relative;
  top: 20px;     /* 向下偏移20px */
  left: 30px;    /* 向右偏移30px */
}

三、绝对定位(Absolute)

特点
  • 元素脱离文档流,不占据空间。
  • 相对于最近的已定位祖先元素。
  • 宽度默认由内容决定。
示例
.parent {
  position: relative;  /* 作为定位参考 */
}

.absolute {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 200px;
}

四、固定定位(Fixed)

特点
  • 元素脱离文档流,相对于浏览器窗口。
  • 滚动时位置保持不变。
  • 常用于导航栏、返回顶部按钮等。
示例
.fixed {
  position: fixed;
  bottom: 20px;
  right: 20px;

五、粘性定位(Sticky)

特点
  • 元素在滚动时固定在某个位置。
  • 初始时按文档流排列,滚动到特定位置后固定。
  • 相对于最近的滚动祖先元素。
示例
.sticky {
  position: sticky;
  top: 0;        /* 滚动到顶部时固定 */
  background: white;
  z-index: 100;
}

OK,CSS就差不多了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2394936.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ESP8266远程控制:实现网络通信与设备控制

概述&#xff1a; 最近一直在弄esp8266的网络通信&#xff0c;但是一直都还没搞懂到底esp8266可不可以通过连接一个网络过后&#xff0c;在很远的地方使用网络将其关掉 在网上找了两个教程都有程序&#xff0c;都跑通了 第一个 第二个找不到了&#xff0c;但是程序有 CSDN上放文…

【机器学习基础】机器学习入门核心算法:隐马尔可夫模型 (HMM)

机器学习入门核心算法&#xff1a;隐马尔可夫模型 &#xff08;HMM&#xff09; 一、算法逻辑与核心思想二、算法原理与数学推导核心问题与算法推导 三、模型评估四、应用案例1. 语音识别 (Speech Recognition)2. 自然语言处理 (Natural Language Processing - NLP)3. 手写体识…

Leetcode 2819. 购买巧克力后的最小相对损失

1.题目基本信息 1.1.题目描述 现给定一个整数数组 prices&#xff0c;表示巧克力的价格&#xff1b;以及一个二维整数数组 queries&#xff0c;其中 queries[i] [ki, mi]。 Alice 和 Bob 去买巧克力&#xff0c;Alice 提出了一种付款方式&#xff0c;而 Bob 同意了。 对于…

AI炼丹日志-25 - OpenAI 开源的编码助手 Codex 上手指南

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇&#xff1a; MyBatis 更新完毕目前开始更新 Spring&#xff0c;一起深入浅出&#xff01; 大数据篇 300&#xff1a; Hadoop&…

C# 类和继承(使用基类的引用)

使用基类的引用 派生类的实例由基类的实例和派生类新增的成员组成。派生类的引用指向整个类对象&#xff0c;包括 基类部分。 如果有一个派生类对象的引用&#xff0c;就可以获取该对象基类部分的引用&#xff08;使用类型转换运算符把 该引用转换为基类类型&#xff09;。类…

进程间通信(消息队列)

目录 一 原理 二 API 1. ftok 2. msgget 3. msgctl 4. msgsnd 5. msgrcv 三 demo代码 四 基于责任链模式和消息队列对数据处理 1. 什么是责任链模式 2. 下面基于责任链模式来对消息队列获取的消息进行处理 前置 其实system v 版本的进程间通信&#xff0c;设计的接…

Nginx--手写脚本压缩和切分日志(也适用于docker)

原文网址&#xff1a;Nginx--手写脚本压缩和切分日志&#xff08;也适用于docker&#xff09;_IT利刃出鞘的博客-CSDN博客 简介 本文介绍nginx如何手写脚本压缩和切分日志。 1.创建切分日志的脚本 创建脚本文件&#xff1a;/work/tmp/nginx-log_sh&#xff08;后边要用run-…

OpenCv高阶(十八)——dlib人脸检测与识别

文章目录 一、dlib库是什么&#xff1f;二、opencv库与dlib库的优缺点对比1、opencv优缺点2、dlib库优缺点 三、dlib库的安装1、在线安装2、本地安装 四、dlib库的人脸检测器1. 基于 HOG 的检测器2. 基于 CNN 的检测器 五、dlib人脸检测的简单使用1、导入必要库2、初始化人脸检…

中山大学无人机具身导航新突破!FlightGPT:迈向通用性和可解释性的无人机视觉语言导航

作者&#xff1a;Hengxing Cai 1 , 2 ^{1,2} 1,2, Jinhan Dong 2 , 3 ^{2,3} 2,3, Jingjun Tan 1 ^{1} 1, Jingcheng Deng 4 ^{4} 4, Sihang Li 2 ^{2} 2, Zhifeng Gao 2 ^{2} 2, Haidong Wang 1 ^{1} 1, Zicheng Su 5 ^{5} 5, Agachai Sumalee 6 ^{6} 6, Renxin Zhong 1 ^{1} …

WIN11+CUDA11.8+VS2019配置BundleFusion

参考&#xff1a; BundleFusion:VS2019 2017 ,CUDA11.5,win11&#xff0c;Realsense D435i离线数据包跑通&#xff0c;环境搭建 - 知乎 Win10VS2017CUDA10.1环境下配置BundleFusion - 知乎 BundleFusionWIN11VS2019 CUDA11.7环境配置-CSDN博客 我的环境&#xff1a;Win 11…

WPF prism

Prism Prism.Dryloc 包 安装 Nuget 包 - Prism.DryIoc 1. 修改 App.xaml 修改 App.xaml 文件&#xff0c;添加 prism 命名空间, 继承由 Application → PrismApplication&#xff0c;删除默认启动 url, StartupUri“MainWindow.xaml” <dryioc:PrismApplicationx:Class…

[Redis] Redis:高性能内存数据库与分布式架构设计

标题&#xff1a;[Redis] 浅谈分布式系统 水墨不写bug 文章目录 一、什么是Redis&#xff1f;一、核心定位二、核心优势三、典型应用场景四、Redis vs 传统数据库 二、架构选择与设计1、单机架构&#xff08;应用程序 数据库服务器&#xff09;2、应用程序和数据库服务器分离3…

React 第四十九节 Router中useNavigation的具体使用详解及注意事项

前言 useNavigation 是 React Router 中一个强大的钩子&#xff0c;用于获取当前页面导航的状态信息。 它可以帮助开发者根据导航状态优化用户体验&#xff0c;如显示加载指示器、防止重复提交等。 一、useNavigation核心用途 检测导航状态&#xff1a;判断当前是否正在进行…

【JavaEE】Spring事务

目录 一、事务简介二、Spring事务的实现2.1 事务的操作2.2 分类2.2.1 Spring编程式事务2.2.2 Spring 声明式事务 Transactional2.2.2.1 Transactional 详解2.2.2.1.1 rollbackFor2.2.2.1.2 Isolation2.2.2.1.3 propagation 一、事务简介 事务&#xff1a;事务是⼀组操作的集合…

Android15 userdebug版本不能remount

背景描述&#xff1a; 最近调试Android Vendor Hal的时候发现一个奇怪的现象: android userdebug版本刷到设备中&#xff0c;执行adb root没提示错误&#xff0c;但是没有获取到root权限。 Android设备运行的系统版本有三种情况&#xff1a;user版本、userdebug版本和eng版本…

R包安装报错解决案例系列|R包使用及ARM架构解决data.table安装错误问题

有不少同学是Mac系统的&#xff0c;分析过程中会发现部分R包总是安装不成功&#xff0c;这是因为部分R包基于windowsx86架构编译的&#xff0c;最常见的就是含 C/C/Fortran 的包&#xff0c;对于初学者都是建议linux和win去做&#xff0c;Windows 通常直接安装预编译好的二进制…

Linux上安装MongoDB

目录 一、在Linux系统安装MongoDB服务器 1、下载MongoDB 2、上传MongoDB并解压 3、创建必要目录 4、配置环境变量 5、创建配置文件 6、启动命令 7、验证安装 二、在Linux系统安装MongoDB客户端Shell 1、下载MongoDB Shell 2、上传MongoDB Shell并解压 3、配置环境变…

Redis最佳实践——安全与稳定性保障之访问控制详解

Redis 在电商应用的安全与稳定性保障之访问控制全面详解 一、安全访问控制体系架构 1. 多层级防护体系 #mermaid-svg-jpkDj2nKxCq9AXIW {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-jpkDj2nKxCq9AXIW .error-ico…

【华为开发者空间 x DeepSeek】服务器运行Ollama并在本地调用

文章概述 本文介绍了如何在 华为开发者空间 中快速部署并使用 Ollama 模型运行框架&#xff0c;并结合 deepseek-r1 模型进行本地或远程交互推理。内容涵盖环境准备、模型配置、网卡绑定、内网穿透、API调用等多个环节&#xff0c;适合希望在华为云上快速搭建本地类大模型推理…

STM32之IIC(重点)和OLED屏

内部集成电路概述 基本概念 内部集成电路&#xff08;Inter Integrated Circuit&#xff09;的简称叫做IIC或者I2C&#xff0c;是一种简单的、半双工同步通信的串行通信接口&#xff0c;IIC总线是上世纪80年代&#xff08;1982年&#xff09;由飞利浦公司设计出来&#xff0c…