HTML-CSS知识速查

news2025/1/23 11:28:33

HTML/CSS知识速查

文章目录

  • HTML/CSS知识速查
    • @[toc]
    • 网页的组成
    • 浏览器
      • **为什么需要Web标准:**
    • **web标准的构成:**
    • HTML
      • HTML语法导读
        • **1.1 HTML语法规则:**
        • 1.2 基本结构标签
        • **1.3 标签的关系:**
          • 1. **包含关系(Parent-Child Relationship)**:
          • 2. **并列关系(Sibling Relationship)**:
      • HTML常用语法
        • 2.1 标题标签
        • 2.2 段落标签:
        • 2.3 换行标签
        • 2.4 文本格式化标签:
        • 2.5 div和span标签
        • 2.6 图片标签:
        • 2.7 路径:
        • 2.8 链接标签:
        • 2.9 注释
        • 2.10 特殊字符
        • 2.11 表格(重点)
        • 2.12 标签分类
    • CSS
      • 一、CSS简介
        • 1.1 CSS语法规范
        • 1.2 CSS 注释
      • 二、CSS选择器
        • CSS选择器的作用
          • CSS基础选择器
          • **类选择器**
          • **多类名选择器**
          • id选择器:
          • 通配符选择器
          • 序号选择器(用于定位)
          • 选择器总结
      • 三、CSS 伪类选择器与伪元素
        • 1. 基本伪类选择器
        • 2. 新增伪类选择器
        • 3. 伪元素
      • 四、CSS字体属性
        • 字体大小
        • 字体粗细
        • 字体样式
        • 字体的综合写法
        • 字体总结
        • 字体的综合写法
        • 字体总结

网页的组成

  1. 网页是图片、链接、文字、声音、视频等元素组成, 其实就是一个html文件(后缀名为html)
  2. 网页生成制作: 有前端人员书写 HTML 文件, 然后浏览器打开,就能看到了网页.
  3. HTML: 超文本标记语言, 用来制作网页的一门语言. 有标签组成的. 比如 图片标签 链接标签 视频标签等…

浏览器

常用的浏览器 + IE + 火狐 + 谷歌 + 苹果 + 欧朋 - 浏览器是网页显示、运行的平台。常用的浏览器有 IE、火狐(Firefox)、谷歌(Chrome)、Safari和Opera等。平时称为五大浏览器。

img

浏览器内核(渲染引擎) + 负责读取网页内容,整理讯息,计算网页的显示方式并显示页面

+ 目前国内一般浏览器都会采用 Webkit/Blink 内核,如 360、UC、QQ、搜狗等。三、web标准:

  • Web 标准是由 W3C 组织和其他标准化组织制定的一系列标准的集合。W3C(万维网联盟)是国际最著名的标准化组织。

为什么需要Web标准:

  • 浏览器不同,它们显示页面或者排版就有些许差异

  • 遵循 Web 标准除了可以让不同的开发人员写出的页面更标准、更统一外,还有以下优点: 1.让 Web 的发展前景更广阔。 2.内容能被更广泛的设备访问。 3.更容易被搜寻引擎搜索。 4.降低网站流量费用。 5.使网站更易于维护。 6.提高页面浏览速度。

web标准的构成:

主要包括 《结构Structure》 、《表现(Presentation)》和《行为(Behavior)》三个方面。

Web 标准提出的最佳体验方案:结构、样式、行为相分离
简单理解:结构写到 HTML 文件中, 表现写到 CSS 文件中, 行为写到 JavaScript 文件中

  1. 结构类似身体
  2. 表现类似外观装饰
  3. 行为类似行为动作
  4. 相比较而言, 三者中结构最重要.

HTML

  1. HTML 指的是超文本标记语言 (Hyper Text Markup Language) ,它是用来描述网页的一种语言。

  2. HTML 不是一种编程语言,而是一种标记语言 (markup language)。

标记语言是一套标记标签 (markup tag)。

HTML语法导读

1.1 HTML语法规则:

HTML 标签是由尖括号包围的关键词,例如 <html>。HTML标签关系可以是嵌套关系,也可以是并列关系

HTML中单标签和双标签的分类

  • 单标签:只有一个标签。

    常见的单标签

    1. <hr /> 标签:
      • <hr /> 标签用于创建一个水平分割线,通常用于分隔内容或定义主题的变化。
    2. <br /> 标签:
      • <br /> 标签用于插入一个换行符,使得内容能在下一行继续。
    3. <meta /> 标签:
      • <meta /> 标签提供了有关页面的元信息,如字符集、页面描述、关键字和作者信息。它还可以用于控制浏览器行为,如设置页面的刷新率。
    4. <img /> 标签:
      • <img /> 标签用于嵌入图像。它有多个属性,如 src(图像源的URL)、alt(替代文本,用于图像无法显示时)、heightwidth(用于指定图像的尺寸)。
    5. <link /> 标签:
      • <link /> 标签用于链接外部资源,如样式表。它通常位于<head>区域内,并且拥有如 href(资源的URL)、rel(资源与当前文档的关系)和 type(资源的MIME类型)等属性。
    6. <input /> 标签:
      • <input /> 标签是表单中非常重要的元素,用于收集用户输入。它有多种类型,如文本、密码、单选按钮、复选框等,通过type属性来定义。
  • 双标签:有开始和结束标签

    1. 文档结构标签:
    • <html></html>: HTML文档的根元素,所有其他元素都嵌套在其中。
    • <head></head>: 包含文档的元信息,如元数据、链接到CSS文件和JavaScript文件。
    • <title></title>: 定义文档的标题,显示在浏览器的标题栏中。
    • <body></body>: 包含文档的所有内容,如文本、图像、视频等。
    1. 标题标签:
    • <h1></h1><h6></h6>: 定义六个级别的标题,<h1>是最高级别(最重要),<h6>是最低级别(最不重要)。
    1. 文本格式化标签:
    • <p></p>: 定义段落。
    • <pre></pre>: 定义预格式化文本,保留文本中的空格和换行。
    • <code></code>: 定义单行代码。
    • <em></em>: 强调文本。
    • <strong></strong>: 强烈强调文本,通常显示为加粗。
    • <i></i>: 斜体文本。
    • <b></b>: 粗体文本。
    • <u></u>: 下划线文本。
    • <mark></mark>: 高亮文本。
    1. 块级元素和内联元素:
    • <div></div>: 块级元素,用于组织内容和应用样式。
    • <span></span>: 内联元素,用于组织内容和应用样式。
    1. 链接和列表:
    • <a></a>: 定义超链接。
    • <ul></ul>: 定义无序列表。
    • <ol></ol>: 定义有序列表。
    • <li></li>: 定义列表项。
    • <dl></dl>: 定义描述列表。
    • <dt></dt>: 定义描述术语。
    • <dd></dd>: 定义描述定义。
    1. 表格:
    • <table></table>: 定义表格。
    • <thead></thead>: 定义表头。
    • <tbody></tbody>: 定义表体。
    • <th></th>: 定义表头单元格。
    • <tr></tr>: 定义表格行。
    • <td></td>: 定义表格数据。
    1. 表单:
    • <form></form>: 定义表单。
    • <label></label>: 定义输入标签。
    • <input></input>: 定义输入字段。
    • <select></select>: 定义下拉列表。
    • <option></option>: 定义下拉列表中的选项。
    • <button></button>: 定义按钮。
    • <textarea></textarea>: 定义多行文本输入字段。
    1. 媒体和脚本
    • <video></video>: 定义视频。
    • <script></script>: 定义客户端JavaScript。
    • <iframe></iframe>: 定义内联框架,可以嵌套其他文档。
1.2 基本结构标签

每个网页都会有一个基本的结构标签(也称为骨架标签),页面内容也是在这些基本标签上书写。

每个HTML文档通常都遵循一个基本的结构,包括以下几个主要的标签组成,通常被称为HTML的骨架。下面是一个简单的示例来展示这些基本结构标签的用法:

<!DOCTYPE html> <!-- 声明文档类型,告诉浏览器这是一个HTML5文档 -->
<html lang="zh-CN"> <!-- 根元素,所有其他HTML元素都嵌套在这里 -->

<head> <!-- 包含页面的元信息,如元数据、CSS链接和JavaScript链接 -->
    <meta charset="UTF-8"> <!-- 定义文档字符集 -->
    <meta name="viewport" content="width=device-width, initial-scale=1"> <!-- 使页面具有响应式特点 -->
    <title>我的第一个网页</title> <!-- 定义页面标题 -->
    <link rel="stylesheet" href="styles.css"> <!-- 链接外部CSS样式表 -->
    <script src="script.js"></script> <!-- 链接外部JavaScript文件 -->
</head>

<body> <!-- 包含页面的所有可见内容 -->
</body>

</html>

在上述代码中:

  1. <!DOCTYPE html> 是文档类型声明,它告诉浏览器这是一个HTML5文档。

  2. <html> 标签是所有其他HTML元素的根元素。

  3. <head> 标签包含了文档的元信息,如字符集声明、页面标题、以及链接到外部CSS和JavaScript文件的标签。

  4. <body> 标签包含了页面的所有可见内容,如头部、导航菜单、主要内容区和底部。在这个例子中,我们还使用了一些其他的结构和内容标签,如 <header>, <nav>, <main>, <section>, 和 <footer>,来组织页面的不同部分。

  5. lang 语言种类

    • 用来定义当前文档显示的语言。
    • en定义语言为英语 zh-CN定义语言为中文 简单来说,定义为en 就是英文网页, 定义为
    • zh-CN 就是中文
    • 简单来说,定义为en 就是英文网页, 定义为 zh-CN 就是中文网页
    • 其实对于文档显示来说,定义成en的文档也可以显示中文,定义成zh-CN的文档也可以显示英文
    • 这个属性对浏览器和搜索引擎(百度.谷歌等)还是有作用的

    字符集:

    • 1.字符集 (Character set)是多个字符的集合。以便计算机能够识别和存储各种文字。
    • 2.在<head>标签内,可以通过<meta> 标签的 charset 属性来规定 HTML 文档应该使用哪种字符编码。
    • charset属性是用于指定文档字符集的。它应该被设置在<meta>标签内,通常放置在<head>区域的顶部。
    • 3.<meta charset=" UTF-8"/>charset 常用的值有:GB2312 、BIG5 、GBK 和 UTF-8,其中 UTF-8 也被称为万国码,基本包含了全世界所有国家需要用到的字符.
    • 5.注意:上面语法是必须要写的代码,否则可能引起乱码的情况。一般情况下,统一使用“UTF-8”编码,尽量统一写成标准的 “UTF-8”,不要写成 “utf8” 或 “UTF8”。

这个基本结构为你创建的每个页面提供了一个清晰、组织良好的框架,你可以在此基础上添加更多内容和样式,以完成你的网页设计。

1.3 标签的关系:

在HTML中,标签之间的关系通常可以归纳为包含关系和并列关系。下面是对这两种关系的解释和示例:

1. 包含关系(Parent-Child Relationship):

包含关系也被称为父子关系。在这种关系中,一个标签(父标签)包含另一个或多个标签(子标签)。子标签被嵌套在父标签中。例如,在您提供的代码中,<head> 标签是 <title> 标签的父标签,而 <title> 标签是 <head> 标签的子标签。其他的包含关系示例如下:

<html>
    <body>
        <div>
            <p></p>
            <p></p>
        </div>
        <div>
            <img />
        </div>
    </body>
</html>

在上面的示例中,<html><body> 的父标签,<body> 是两个 <div> 标签的父标签,第一个 <div> 是两个 <p> 标签的父标签,而第二个 <div><img> 标签的父标签。

2. 并列关系(Sibling Relationship):

并列关系是指在同一级别上的标签,它们共享同一个父标签。这些标签被称为兄弟标签(或同级标签)。例如:

<body>
    <div></div>
    <div></div>
    <img />
</body>

在上面的示例中,两个 <div> 标签和一个 <img> 标签是兄弟标签,因为它们都是 <body> 标签的直接子标签。

这两种关系是理解和组织HTML文档结构的基础,它们帮助开发人员清楚地理解标签之间的层级和关联,也便于通过CSS和JavaScript对页面元素进行样式设计和交互处理。

HTML常用语法

2.1 标题标签

标题标签 <h1> - <h6>(重要)

  • 具体实现
<h1> 我是一级标题 </h1>

特点

  1. 标题文字会自动加粗,字号也会依次变大。
  2. 每个标题独占一行。
<h1>标题一共六级选,</h1>
<h2>文字加粗一行显。</h2>
<h3>由大到小依次减,</h3>
<h4>从重到轻随之变。</h4>
<h5>语法规范书写后,</h5>
<h6>具体效果刷新见。</h6>
2.2 段落标签:
  • 具体实现
<p> 我是一个段落标签 </p>

特点

  1. 文本在一个段落中会根据浏览器窗口的大小自动换行。
  2. 段落和段落之间保有空隙。
2.3 换行标签
  • 具体实现
<br />
  • 特点:
    1. <br /> 是个单标签。
    2. <br /> 标签只是简单地开始新的一行,与段落不同,段落之间会插入一些垂直的间距。
2.4 文本格式化标签:
  • 粗体:<b></b>,斜体:<i></i>,下划线:<u></u>
2.5 div和span标签
  • 具体实现
<div> 这是头部 </div>    
<span> 今日价格 </span>
  • 特点

    1. <div> 标签用来布局,但是现在一行只能放一个<div>。大盒子
    2. <span> 标签用来布局,一行上可以多个 <span>。小盒子
2.6 图片标签:
  • 具体实现
<img src="图像URL" />
  • 解释:
    • src<img>标签的必须属性,它用于指定图像文件的路径和文件名。

图像标签的其他属性:

属性名属性值描述
src图片路径图片路径,是必须属性
alt文本提供图像不可见时的文本
width像素指定图像的宽度
height像素指定图像的高度
broder像素设置图像边框的粗细
title文本提示文本,鼠标放到图片上弹出的文本提示

图像标签注意点

  1. 图像标签可以拥有多个属性,必须写在标签名的后面。
  2. 属性之间不分先后顺序,标签名与属性、属性与属性之间均以空格分开。
  3. 属性采取键值对的格式,即 key=“value" 的格式,属性 =“属性值”。
2.7 路径:
  • 相对路径:以引用文件所在位置为参考基础,而建立出的目录路径。
  • 绝对路径:是指目录下的绝对位置,直接到达目标位置,通常是从盘符开始的路径。例如,“D:\web\img\logo.gif”或完整的网络地址“http://www.itcast.cn/images/logo.gif”
2.8 链接标签:
  • 链接的语法格式
<a href="跳转目标" target="目标窗口的弹出方式"> 文本或图像 </a>
  • 属性:
    1. href:用于指定链接目标的url地址
    2. target:用于指定链接页面的打开方式 _self默认值 _blank新窗口打开
    3. #:空链接

链接分类

  1. 外部链接
  2. 内部链接
  3. 空链接
  4. 下载链接
  5. 网页元素链接
  6. 锚点链接
2.9 注释
  • 具体实现
<!-- 这是一个注释 -->
  • 解释:
    • HTML中的注释以“ ”结束。注释标签里面的内容是给程序员看的, 这个代码是不执行不显示到页面中的。添加注释是为了更好地解释代码的功能,便于相关开发人员理解和阅读代码,程序是不会执行注释内容的
2.10 特殊字符

在 HTML 页面中,一些特殊的符号很难或者不方便直接使用,此时我们就可以使用下面的字符来替代。

特殊字符描述字符的代码
<空格符&nbsp;
<小于号&lt;
>大鱼号&gt;
&和号&amp;
人民币&yen;
©版权&copy;
®注册商标&reg;
°摄氏度&deg;
±正负号&plusmn;
×乘号&times;
÷除号&divide;
²平方2&sup2;
³立方3&sup3;

重点记住:空格 、大于号、 小于号 这三个, 其余的使用很少。

2.11 表格(重点)

HTML表格用于显示行和列数据。表格由<table>元素创建,其中包括若干行(由<tr>元素创建),每行包括若干列(由<td>元素创建)。另外,还可以使用<th>元素创建表头单元格,这些单元格通常用于显示列的标题。下面是HTML表格中使用的主要标签和属性的详细介绍及示例:

  1. <table>标签:用于创建表格。

    <table border="1">
        <!-- 表格内容 -->
    </table>
    
  2. <tr>标签:用于创建表格行。

    <tr>
        <!-- 表格列内容 -->
    </tr>
    
  3. <td>标签:用于创建表格数据单元格。

    <td>数据</td>
    
  4. <th>标签:用于创建表格头单元格。

    <th>标题</th>
    
  5. colspan属性:用于指定单元格应横跨的列数。

    <td colspan="2">数据</td>
    
  6. rowspan属性:用于指定单元格应纵跨的行数。

    <td rowspan="2">数据</td>
    
  7. <thead>标签:用于组合表格头部内容。

    <thead>
        <!-- 表头行和列 -->
    </thead>
    
  8. <tbody>标签:用于组合表格主体内容。

    <tbody>
        <!-- 主体行和列 -->
    </tbody>
    
  9. <tfoot>标签:用于组合表格底部内容。

    <tfoot>
        <!-- 底部行和列 -->
    </tfoot>
    

下面是一个包括了跨行、跨列和合并单元格的完整HTML表格示例:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Table Example</title>
</head>
<body>

<table border="1">
    <thead>
        <tr>
            <th colspan="3">表格标题</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td rowspan="2">跨两行</td>
            <td>数据1</td>
            <td>数据2</td>
        </tr>
        <tr>
            <td colspan="2">跨两列</td>
        </tr>
        <tr>
            <td>数据3</td>
            <td>数据4</td>
            <td>数据5</td>
        </tr>
    </tbody>
    <tfoot>
        <tr>
            <td colspan="3">表格底部</td>
        </tr>
    </tfoot>
</table>

</body>
</html>

在这个示例中,我们创建了一个表格,其中包括表头、主体和底部。我们使用colspan属性使表头和底部的单元格横跨三列,使用rowspan属性使一个单元格纵跨两行。同时,我们在主体的一行中使用colspan属性使一个单元格横跨两列。

实例代码:课程表

<!DOCTYPE html>
<html lang="zh-CN">
    <head>
        <meta charset="utf-8">
        <title>test</title>
    </head>
<body>
    <h1 style="text-align: center;color: red;">Test</h1>
    <div>
        <table border="1" style="align-items: center;margin: auto;">
        <thead>
            <tr>
                <th colspan="8">课程表</th> <!-- 使"课程表"字样横跨所有列 -->
            </tr>
            <tr>
                <th>节次</th>
                <th>星期一</th>
                <th>星期二</th>
                <th>星期三</th>
                <th>星期四</th>
                <th>星期五</th>
                <th>星期六</th>
                <th>星期天</th>
            </tr>
        </thead>
        
            <tbody>
                <tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr>
                <tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr><tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr><tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr><tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr><tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr><tr>
                    <td>第一节</td>
                    <td>A</td>
                    <td>B</td>
                    <TD>C</TD>
                    <TD>D</TD>
                    <TD>E</TD>
                    <td>F</td>
                    <td>G</td>
                </tr>
            </tbody>
            
        </table>

    </div>
</body> 
</html>

Test

课程表
节次星期一星期二星期三星期四星期五星期六星期天
第一节ABCDEFG
第一节ABCDEFG
第一节ABCDEFG
第一节ABCDEFG
第一节ABCDEFG
第一节ABCDEFG
第一节ABCDEFG
2.12 标签分类

块级元素:

  • 独占一行、内容决定高度、继承父宽、可设置宽高
  • div、p、h系列、ul、li、dl、dt、dd、form、header、nav、footer……

行内元素:

  • 一行显示多个、内容决定宽高、不可以设置宽高
  • a、span 、b、u、i、s、strong、ins、em、del……

行内块元素:

  • 一行可以显示多个、可设置宽高
  • input、textarea、img、button、select
属性效果使用效率
display: block转换成块级元素较多
display: inline-block转化为行内块元素较多
display: inline转化成行内元素极少

HTML嵌套规范注意点

  1. 块级元素一般作为大容器,可以嵌套:文本、块级元素、行内元素、行内块元素等等…
    • p标签中不要嵌套div、p、h等块级元素
  2. a标签内部可以嵌套任意元素
  • a标签不能嵌套a标签

居中方法总结

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

CSS

一、CSS简介

CSS 是层叠样式表 ( Cascading Style Sheets ) 的简称.
有时我们也会称之为 CSS 样式表或级联样式表。

CSS 是也是一种标记语言

CSS 主要用于设置 HTML 页面中的文本内容(字体、大小、对齐方式等)、图片的外形(宽高、边框样式、边距等)以及版面的布局和外观显示样式。

CSS 让我们的网页更加丰富多彩,布局更加灵活自如。简单理解:CSS 可以美化 HTML , 让 HTML 更漂亮, 让页面布局更简单。

CSS 最大价值: 由 HTML 专注去做结构呈现,样式交给 CSS,即 结构 ( HTML ) 与样式( CSS ) 相分离

CSS的应用方式

  1. 内联样式:在标签中包括一个style属性,并在其后定义CSS属性及值,例如:

Hello world!

<p style="color:red"> Hello world! </p>
  1. 文档级样式表:将一系列样式规则罗列在HTML文档开头,处于内的之间,它可以改变外部样式表中定义的一个或多个规则,创建一个个性化的文档,适用于单个HTML文件。

  2. 外部样式表:将样式定义放置于分离的文档中,在各个需要应用该样式表的HTML通过在内的标签引入这个分离文档,例如。每次打开页面都需要下载这个表格,所以要尽量减小样式表的容量。

注意:三种样式表作用域不同,同时存在时的页面处理原则为:

  • “近优先于远”——内联样式>文档级样式。
  • “局部优先于整体”——定义为标签的类的属性>为标签总体进行定义的属性
  • “特殊优先于一般”——上下文样式>为标签总体进行定义的属性
  • “后优先于前”——后边指定的属性>前面指定的属性
1.1 CSS语法规范

1.使用 HTML 时,需要遵从一定的规范,CSS 也是如此。要想熟练地使用 CSS 对网页进行修饰,首先需要了解CSS 样式规则。

2.CSS 规则由两个主要的部分构成:选择器以及一条或多条声明。

img

选择器通常是您需要改变样式的 HTML 元素。

  • 1.选择器是用于指定 CSS 样式的 HTML 标签,花括号内是对该对象设置的具体样式
  • 2.属性和属性值以“键值对”的形式出现
  • 3.属性是对指定的对象设置的样式属性,例如字体大小、文本颜色等
  • 4.属性和属性值之间用英文“:”分开
  • 5.多个“键值对”之间用英文“;”进行区分

CSS声明总是以分号 ; 结束,声明总以大括号 {} 括起来:

p {color:red;text-align:center;}

为了让CSS可读性更强,你可以每行只描述一个属性:

p
{
    color:red;
    text-align:center;
}
1.2 CSS 注释

注释是用来解释你的代码,并且可以随意编辑它,浏览器会忽略它。

CSS注释以 /* 开始, 以 */ 结束, 实例如下:

/*这是个注释*/
p
{
    text-align:center;
    /*这是另一个注释*/
    color:black;
    font-family:arial;
}

二、CSS选择器

CSS选择器的作用

选择器(选择符)就是根据不同需求把不同的标签选出来这就是选择器的作用。 简单来说,就是选择标签用的。

h1 { /*h1是选择器,选择h1标签*/
	color: red;	/* color是标签,red是值*/
	font-size: 25px;
}

这里的意思是:找到所有的 h1 标签。 选择器(选对人) 设置这些标签的样式,比如颜色为红色(做对事)。

CSS基础选择器

基础选择器又包括:标签选择器、类选择器、id 选择器和通配符选择器

标签选择器:

标签选择器(元素选择器)是指用 HTML 标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的 CSS 样式。

/*如上*/
h1 {
	color: red;
	font-size: 20px;
}
类选择器

如果想要差异化选择不同的标签,单独选一个或者某几个标签,可以使用类选择器.

语法:

.类名 {
    属性1: 属性值1;  
    ...
} 
结构需要用class属性来调用  class  类的意思
<div class="类名"> 变红色 </div>

1.如果想要差异化选择不同的标签,单独选一个或者某几个标签,可以使用类选择器。

2.类选择器在 HTML 中以 class 属性表示,在 CSS 中,类选择器以一个点“.”号显示。

3.类选择器使用“.”(英文点号)进行标识,后面紧跟类名(自定义,我们自己命名的)。

4.可以理解为给这个标签起了一个名字,来表示。

5.长名称或词组可以使用中横线来为选择器命名。

6.不要使用纯数字、中文等命名,尽量使用英文字母来表示。

多类名选择器

多类名选择器是CSS中的一个强大功能,它允许你为HTML元素指定多个类名,并按照这些类名来应用样式。当一个元素具有多个类名时,它会继承所有相关类的样式。如果同一个样式属性在多个类中被定义,那么最后一个类的属性值会被应用。

语法:

在HTML中,你可以通过空格分隔每个类名,为元素指定多个类名:

<div class="class1 class2 class3">...</div>

在CSS中,你可以通过以下方式选择具有多个类名的元素:

/* 选择同时具有 class1 和 class2 的元素 */
.class1.class2 {
  /* styles */
}

/* 或者,你可以为每个类分别定义样式 */
.class1 {
  /* styles */
}
.class2 {
  /* styles */
}

示例:

HTML代码

<div class="box highlighted">这是一个同时具有 box 和 highlighted 类名的元素。</div>

CSS代码

.box {
  width: 200px;
  height: 200px;
  border: 1px solid black;
}

.highlighted {
  background-color: yellow;
}

在上面的例子中,<div>元素同时具有boxhighlighted两个类名。所以,它将获得box类定义的边框样式,以及highlighted类定义的背景颜色样式。

  1. 在标签class 属性中写 多个类名
  2. 多个类名中间必须用空格分开
  3. 这个标签就可以分别具有这些类名的样式
id选择器:

id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。

HTML 元素以 id 属性来设置 id 选择器,CSS 中 id 选择器以“#" 来定义。

语法:

HTML代码

<div id="i_Test">Hello World</div>

CSS代码

#id名 {
    属性1: 属性值1;  
    ...
} 

注意:id 属性只能在每个 HTML 文档中出现一次

id选择器和类选择器的区别:

  • 1.类选择器(class)好比人的名字,一个人可以有多个名字,同时一个名字也可以被多个人使用。
  • 2.id 选择器好比人的身份证号码,全中国是唯一的,不得重复。
  • 3.id 选择器和类选择器最大的不同在于使用次数上。
  • 4.类选择器在修改样式中用的最多,id 选择器一般用于页面唯一性的元素上,经常和 JavaScript 搭配使用。
通配符选择器

通配符选择器不需要调用, 自动就给所有的元素使用样式

* {
    属性1: 属性值1;  
    ...
}

* {
    margin: 0;
    padding: 0;
} 
序号选择器(用于定位)
序号选择器意义用法
:first-child选择其父元素的第一个子元素css ul > li:first-child { color: red; }
:last-child选择其父元素的最后一个子元素css ul > li:last-child { color: blue; }
:nth-child(n)选择其父元素的第 n 个子元素css ul > li:nth-child(2) { color: green; }
:nth-last-child(n)选择其父元素的倒数第 n 个子元素css ul > li:nth-last-child(2) { color: purple; }
:only-child选择其父元素只有一个子元素的元素css ul > li:only-child { font-weight: bold; }
:first-of-type选择指定类型的第一个子元素css p:first-of-type { text-decoration: underline; }
:last-of-type选择指定类型的最后一个子元素css p:last-of-type { text-decoration: overline; }
:nth-of-type(n)选择指定类型的第 n 个子元素css p:nth-of-type(2) { font-style: italic; }
:nth-last-of-type(n)选择指定类型的倒数第 n 个子元素css p:nth-last-of-type(2) { background-color: yellow; }
:only-of-type选择指定类型且父元素只有一个该类型子元素的元素css p:only-of-type { text-align: center; }

序号选择器的用法通常涉及到父元素和子元素的关系。通过这些选择器,你可以非常具体地定位到某个元素,无论是基于它在父元素中的位置还是它的类型。在上述的用法示例中,你可以看到如何使用每个序号选择器来应用特定的样式。

选择器总结
基础选择器作用特点使用情况用法
标签选择器可以选出所有相同的标签,比如 p不能差异化选择较多p{color: red;}
类选择器选出具有指定类的元素,比如 .intro可差异化选择元素较多.intro{font-size: 20px;}
ID选择器选出具有指定ID的元素,比如 #unique选择唯一的元素较少#unique{border: 1px solid;}
属性选择器根据元素的属性和值来选择元素灵活且具体较少[type="text"]{background-color: blue;}
通配符选择器选出所有元素选择范围广泛较少*{margin: 0; padding: 0;}
后代选择器选出某元素的所有后代元素结构化选择较多article p{color: green;}
子元素选择器选出某元素的直接子元素结构化且具体较多ul>li{list-style: none;}
伪类选择器根据元素的特定状态来选择元素,比如:hover状态化选择较多a:hover{color: purple;}
伪元素选择器创建元素的某个部分的样式,比如 ::before创建虚拟元素较少p::before{content: "Read this: ";}
分组选择器将多个选择器分组,应用相同的样式合并样式较多h1, h2, h3 {color: blue;}
否定选择器选出不匹配指定选择器的所有元素反向选择较少:not(p){font-style: italic;}

三、CSS 伪类选择器与伪元素

CSS 伪类和伪元素允许你根据元素的特定状态或位置应用样式,而无需添加额外的类或 ID。

1. 基本伪类选择器
伪类意义用法
:link选择所有未被访问的链接css a:link { color: blue; }
:visited选择所有被访问过的链接css a:visited { color: purple; }
:hover选择鼠标指针浮动在上面的元素css a:hover { color: red; }
:active选择活动链接,鼠标点击未松开状态css a:active { color: green; }
:focus选择获得焦点的元素css input:focus { border-color: red; }

注意书写伪类的顺序应该是::link => :visited => :hover => :active,若是单个标签使用多个伪类不按照这个熟悉写会无效。

示例

CSS代码

/* 将超链接的下划线去除,更改颜色 */
a{
    text-decoration: none;
    color: #000000;
}

/* :hover 触碰到效果 */
a:hover{
	color: #FF0000;
}

/* :active 点击不松开效果 */
a:active{
	color: #0000FF;
}

/* text-shadow 文本阴影效果
三个数字分别为:水平阴影的位置 垂直阴影的位置 模糊的距离
十六进制表示:阴影的颜色
*/
.p1{
	text-shadow: 3px 3px 2px #000000 ;
}

完整HTML代码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      /* 将超链接的下划线去除,更改颜色 */
      a{
        text-decoration: none;
        color: #000000;
      }
      
      /* :hover 触碰到效果 */
      a:hover{
        color: #FF0000;
      }
      
      /* :active 点击不松开效果 */
      a:active{
        color: #0000FF;
      }
      
      /* text-shadow 文本阴影效果
       三个数字分别为:水平阴影的位置 垂直阴影的位置 模糊的距离
       十六进制表示:阴影的颜色
       */
      .p1{
        text-shadow: 3px 3px 2px #000000 ;
      }
      
      
    </style>
  </head>
  <body>
    <p>
      <a href="https://www.example.com/">Example</a>
    </p>
    
    <p>
      <a href="#">长路's宠物</a>
    </p>
    <p>
      <a href="#">布丁布丁</a>
    </p>
    <p class="p1">
      <a href="#">$9999.99</a>
    </p>

  </body>
</html>

在上述 HTML 代码中,我们在<style>标签内定义了几个基本伪类选择器的样式规则,并在<body>标签内提供了相应的 HTML 元素来演示这些伪类选择器的效果。具体来说,我们为<a>标签和<input>标签分别应用了不同的伪类选择器样式。

2. 新增伪类选择器
伪类选择器描述参考代码
:empty选择空标签(空格不算空标签):empty { border: 2px solid red; }
:focus选择当前获得焦点的表单元素:focus { border-color: green; }
:enabled选择当前有效的表单元素:enabled { background-color: lightgreen; }
:disabled选择当前无效的表单元素:disabled { background-color: lightgray; }
:checked选择当前已经勾选的单选按钮或者复选框:checked { border: 2px solid blue; }
:root选择根元素(即可看做标签):root { --main-bg-color: pink; background-color: var(--main-bg-color); }

示例

CSS代码

div {
    width: 50px;
    height: 50px;
    border: 1px solid red;
    display: inline-block;
}

/* 空元素:背景元素为蓝色 */
div:empty {
    background-color: blue;
}

/* 获得焦点元素:背景颜色为橙色 */
input:focus {
    background-color: orange;
}

/* 有效的表单:设置长宽 */
input[type='text']:enabled {
    width: 70px;
    height: 20px;
}

/* 无效的表单(disabled):背景颜色为蓝色 */
input:disabled {
    background-color: blue;
}

/* 勾选选中:字体颜色为红色 */
input[type='radio']:checked+span {
    color: red;
}

/* :root(选择根元素,相当于html标签):令字体为20px */
:root {
    font-size: 20px;
}

完整HTML代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            width: 50px;
            height: 50px;
            border: 1px solid red;
            display: inline-block;
        }

        /* 空元素:背景元素为蓝色 */
        div:empty {
            background-color: blue;
        }

        /* 获得焦点元素:背景颜色为橙色 */
        input:focus {
            background-color: orange;
        }

        /* 有效的表单:设置长宽 */
        input[type='text']:enabled {
            width: 70px;
            height: 20px;
        }

        /* 无效的表单(disabled):背景颜色为蓝色 */
        input:disabled {
            background-color: blue;
        }

        /* 勾选选中:字体颜色为红色 */
        input[type='radio']:checked+span {
            color: red;
        }

        /* :root(选择根元素,相当于html标签):令字体为20px */
        :root {
            font-size: 20px;
        }
    </style>
</head>

<body>

    <div></div>
    <div><span>123</span></div>
    <div></div>
    <div>123</div>
    <div></div>

    <!-- 标签部分 -->
    <p>
        <input type="text">
        <input type="text">
        <input type="text" disabled>
        <input type="text" disabled>
        <input type="text">
    </p>

    <!-- 单选框选中 -->
    <p>
        <input type="radio" name="exercise"><span>跑步</span>
        <input type="radio" name="exercise"><span>篮球</span>
        <input type="radio" name="exercise"><span>足球</span>
        <input type="radio" name="exercise"><span>音乐</span>
    </p>

</body>

</html>

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

3. 伪元素

CSS3新增了"伪元素"特性,顾名思义就是表示虚拟动态创建的元素。

伪元素意义用法
::first-line选择元素的第一行p::first-line { font-weight: bold; }
::first-letter选择元素的第一个字母p::first-letter { font-size: 2em; }
::before在元素之前插入内容p::before { content: "Important: "; }
::after在元素之后插入内容p::after { content: "."; }
::selection应用被用户选中的部分(一般使用于文字,即使用鼠标圈选的部分)::selection {color: red;}

伪类选择器和伪元素为开发者提供了强大的功能,使他们能够在不增加额外标记的情况下应用复杂的样式。通过理解和利用这些伪类和伪元素,可以极大地提高CSS的表现力和可维护性。

说明:虚拟创建的内容都会被添加到指定元素的内部。

应用:可以在列表项前面添加小图标。

示例

CSS代码

/* 选择元素的第一行 */
p::first-line {
    font-weight: bold;
}

/* 选择元素的第一个字母 */
p::first-letter {
    font-size: 2em;
}

/* 在元素之前插入内容 */
p::before {
    content: "Important: ";
}

/* 在元素之后插入内容 */
p::after {
    content: ".";
}

完整HTML代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
    /* 选择元素的第一行 */
    p::first-line {
        font-weight: bold;
        background-color: lightblue;  /* 新增背景颜色 */
        color: darkblue;  /* 新增文本颜色 */
    }

    /* 选择元素的第一个字母 */
    p::first-letter {
        font-size: 2em;
        border: 2px solid red;  /* 新增边框 */
    }

    /* 在元素之前插入内容 */
    p::before {
        content: "Important: ";
        color: green;  /* 新增文本颜色 */
    }

    /* 在元素之后插入内容 */
    p::after {
        content: ".";
        font-size: 3em;  /* 新增字体大小 */
    }
</style>
</head>
<body>

<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla volutpat libero vitae velit facilisis, sit amet luctus elit vulputate. Vivamus vestibulum id magna a tincidunt.</p>

</body>
</html>

在上述代码中,我们使用了四种伪元素选择器 ::first-line, ::first-letter, ::before, 和 ::after。每种伪元素选择器都能够为元素应用特定的样式或插入新的内容。这些伪元素选择器为开发者提供了更多的样式控制选项,能够帮助创建富有创意和功能的网页设计。

示例1:::before与::after使用

<html>
    <style>
        /* a标签前虚拟动态创建☆ */
        a::before {
            content: '☆';
        }

        /* a标签后虚拟动态创建☆ */
        a::after {
            content: '❀';
        }
    </style>
    <body>
        <a href="#">点我试试</a>
        <a href="#">点我试试</a>
        <a href="#">点我试试</a>
        <a href="#">点我试试</a>
    </body>
</html>
    

四、CSS字体属性

字体大小

CSS 使用 font-size 属性定义字体大小。

语法:

     p {  
        font-size: 20px; 
    }

1.px(像素)大小是我们网页的最常用的单位

2.谷歌浏览器默认的文字大小为16px

3.不同浏览器可能默认显示的字号大小不一致,我们尽量给一个明确值大小,不要默认大小

4.可以给 body 指定整个页面文字的大小

字体粗细

CSS 使用 font-weight 属性设置文本字体的粗细。

语法:

p {  
	font-weight: bold; 
}
属性值描述
normal默认值(不加粗)
bold定义粗体(加粗的)
100-900400 等同于 normal,而700等同于bold(这两个后面不跟单位)
字体样式

CSS 使用 font-style 属性设置文本的风格。

p {  
	font-style: normal;
}
属性值描述
normal默认值(不加粗)
italic浏览器会显示斜体的字体样式
字体的综合写法
body {   font: font-style  font-weight  font-size/line-height  font-family;}

使用 font 属性时,必须按上面语法格式中的顺序书写,不能更换顺序,并且各个属性间以空格隔开 不需要设置的属性可以省略(取默认值),但必须保留 font-size 和 font-family 属性,否则 font 属性将不起作用

字体总结
属性表示注意点
font-size字号通常是px像素单位,要带上单位,也可以使用 em, rem, % 等其他单位
font-family字体通常包括多个字体名称,作为备选方案。例如: “Helvetica, Arial, sans-serif”
font-weight字重常用值有 normal, bold, bolder, lighter 或 100 到 900 之间的数字
font-style字体样式常用值有 normal, italic, oblique
line-height行高可以是无单位的数字,也可以是具有单位的值,例如 px, em, % 等
text-align文本对齐常用值有 left, right, center, justify
text-decoration文本装饰常用值有 none, underline, overline, line-through
text-transform文本转换常用值有 uppercase, lowercase, capitalize
color颜色可以是颜色名称、十六进制代码、rgb 值等多种表达方式
letter-spacing字母间距通常使用 px, em 等单位,也可以设置为 normal 表示默认间距
word-spacing单词间距通常使用 px, em 等单位,也可以设置为 normal 表示默认间距
属性值描述
normal默认值(不加粗)
italic浏览器会显示斜体的字体样式
字体的综合写法
body {   font: font-style  font-weight  font-size/line-height  font-family;}

使用 font 属性时,必须按上面语法格式中的顺序书写,不能更换顺序,并且各个属性间以空格隔开 不需要设置的属性可以省略(取默认值),但必须保留 font-size 和 font-family 属性,否则 font 属性将不起作用

字体总结
属性表示注意点
font-size字号通常是px像素单位,要带上单位,也可以使用 em, rem, % 等其他单位
font-family字体通常包括多个字体名称,作为备选方案。例如: “Helvetica, Arial, sans-serif”
font-weight字重常用值有 normal, bold, bolder, lighter 或 100 到 900 之间的数字
font-style字体样式常用值有 normal, italic, oblique
line-height行高可以是无单位的数字,也可以是具有单位的值,例如 px, em, % 等
text-align文本对齐常用值有 left, right, center, justify
text-decoration文本装饰常用值有 none, underline, overline, line-through
text-transform文本转换常用值有 uppercase, lowercase, capitalize
color颜色可以是颜色名称、十六进制代码、rgb 值等多种表达方式
letter-spacing字母间距通常使用 px, em 等单位,也可以设置为 normal 表示默认间距
word-spacing单词间距通常使用 px, em 等单位,也可以设置为 normal 表示默认间距

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

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

相关文章

PostgreSQL-SQL联表查询LEFT JOIN 数据去重复

我们在使用left join联表查询时&#xff0c;如果table1中的一条记录对应了table2的多条记录&#xff0c;则会重复查出id相同的多条记录。 1、解决方法一 SELECT t1.* FROM table1 t1 LEFT JOIN table2 t2 ON t1.id t2.tid 第一种方法我们发现还是有重复数据 2、解决方法二…

Diffusion:通过扩散和逆扩散过程生成图像的生成式模型

在当今人工智能大火的时代&#xff0c;AIGC 可以帮助用户完成各种任务。作为 AIGC 主流模型的 DDPM&#xff0c;也时常在各种论文中被提起。DDPM 本质就是一种扩散模型&#xff0c;可以用来生成图片或者为图片去噪。 扩散模型定义了一个扩散的马尔科夫过程&#xff0c;每一步逐…

删除排序链表的重复元素I和II,多种解法和思考

删除排序链表的重复元素I https://leetcode.cn/problems/remove-duplicates-from-sorted-list/description/ 一个循环就可以了&#xff0c;如果当前节点和下一个节点值一样&#xff0c;当前节点不移动让next后移动一个&#xff0c;如果不一样则当前节点后移。 一个循环就可以…

mysql8报sql_mode=only_full_group_by(存储过程一直报)

1&#xff1a;修改数据库配置(重启失效) select global.sql_mode;会打印如下信息 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION里面包含 ONLY_FULL_GROUP_BY&#xff0c;那么就重新设置&#xff0c;在数据库中输入以下代码&#xff0c;去掉ONLY_FULL_GROU…

水果编曲软件FL Studio21最新中文版本2023年最新FL 21中文版如何快速入门教程

水果编曲软件FL Studio介绍 各位&#xff0c;大家晚上好&#xff0c;今天给大家带来最新最新2023水果编曲软件FL Studio 21中文版下载安装激活图文教程。我们一起先了解一些FL Studio 。FL Studio21是目前流行广泛使用人数最多音乐编曲宿主制作DAW软件&#xff0c;这款软件相信…

PyQt基础_007_ 按钮类控件QCombox

import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import *class ComboxDemo(QWidget):def __init__(self, parentNone):super(ComboxDemo, self).__init__(parent)self.setWindowTitle("combox 例子") self.resize(300, 90) …

【智能算法】改进粒子群优化算法及对比分析

程序名称&#xff1a;改进粒子群优化算法及对比分析 实现平台&#xff1a;matlab 代码简介&#xff1a;基本粒子群算法(BPSO)中&#xff0c;每个优化问题的解都可以看作粒子在搜索空间中的位置&#xff0c;粒子通过飞行速度决定它们的搜索方向和搜索范围&#xff0c;粒子群通…

C语言基础--#if与#endif

目录 一、C语言中的 #if()和 #end if 用法 1. #if 表达式 程序段 #endif 形式 2. #ifdef标示符 标识符 #endif 形式 3. #if 0/ #if 1 #endif 形式 4. \可用于一行的结尾&#xff0c;表示本行与下一行连接起来 二、xTaskCreate函数 三、指针相关…

投资者要不要更换黄金代理?

有一些投资者会问&#xff0c;要不要更换自己的黄金代理&#xff1f;笔者认为&#xff0c;换代理这个问题有一些东西需要关注。因此&#xff0c;我们今天就来讨论一下投资者该不该更改代理&#xff1f;如果要换&#xff0c;新的代理如何选择&#xff1f; 其实很简单&#xff0c…

数据结构-构造哈夫曼树【详解+代码+图示】一文解惑!

哈夫曼树 (Huffman Tree) 文章目录 哈夫曼树 (Huffman Tree)导论构造哈夫曼树语言描绘图形化理解 证明结论代码实现测试结果对照总结 导论 我们在学习哈夫曼树之前需要先了解 什么是哈夫曼树? 哈夫曼树 是一种最优树,是一类带权路径长度最短的二叉树,通过哈夫曼算法可以构建一…

虚幻学习笔记7—蓝图接口

一、前言 蓝图接口就是可以在蓝图中实现的接口&#xff0c;有它方便的地方&#xff0c;可以很方便的调用到实现了接口的函数。 二、实现 2.1、创建一个蓝图接口 1&#xff09;可以添加多个函数。 2&#xff09;函数在蓝图接口中只能规定输入和输出参数。 只有输入参数的可以…

Vue3生命周期函数(简述题)

1.图示 2.说明 3.补充 1.在vue3组合式API中&#xff0c;我们需要将生命周期函数先导入&#xff0c;然后才能使用。 import {onMounted} from vue2.beforeCreate和created被setup()方法所代替

Revit导出3D模型插件【GLTF|OBJ|DAE|STL|PLY|OFF|XYZ】

3dconvert_for_revit插件是NSDT 3DConvert工具集中的一种&#xff0c;可以快速将Revit模型导出为8种目标格式&#xff1a;GLTF、OBJ、GLB、DAE、STL、OFF、XYZ和PLY。 用户在进行格式转换之前&#xff0c;需要先下载安装对应Revit版本的插件。 NSDT在线工具推荐&#xff1a; T…

RabbitMQ消息模型之发布订阅Publish-Subscribe

发布订阅模型 Publish/Subscribe 发布订阅模型也称为广播模型&#xff0c;交换机类型需要指定为Fanout&#xff0c;正如从名称中猜到的那样&#xff0c;它是将接收到的所有消息广播到它知道的所有队列中。每个消费者都监听自己的队列&#xff0c;所以同一个消息&#xff0c;会…

多模块项目打包部署

目录结构 这些模块间相互依赖&#xff0c;打包的时候打父模块&#xff0c;就是带root的这个 先clean&#xff0c;再package&#xff0c;就跟一般的项目一样了。 有可能遇到报错Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.22.2:test&#xff…

[Java]JUC并发编程

JUC并发编程 一、什么是JUC 使用到 java.util 工具包、包、分类 二、线程和进程 进程&#xff1a;一个正在运行的程序&#xff0c;QQ.exe Music.exe 程序的集合&#xff1b; 一个进程往往可以包含多个线程&#xff0c;至少包含一个&#xff01; Java默认有两个线程&#x…

微服务链路追踪组件SkyWalking实战

概述 微服务调用存在的问题 串联调用链路&#xff0c;快速定位问题&#xff1b;理清服务之间的依赖关系&#xff1b;微服务接口性能分析&#xff1b;业务流程调用处理顺序&#xff1b; 全链路追踪&#xff1a;对请求源头到底层服务的调用链路中间的所有环节进行监控。 链路…

短 URL 生成器设计:百亿短 URL 怎样做到无冲突?

Java全能学习面试指南&#xff1a;https://javaxiaobear.cn 我们先来看看&#xff0c;当高并发遇到海量数据处理时的架构。在社交媒体上&#xff0c;人们经常需要分享一些 URL&#xff0c;但是有些 URL 可能会很长&#xff0c;比如&#xff1a; https://time.geekbang.org/hyb…

C#图像处理OpenCV开发指南(CVStar,03)——基于.NET 6的图像处理桌面程序开发实践第一步

1 Visual Studio 2022 开发基于.NET 6的OpenCV桌面程序 1.1 为什么选择.NET 6开发桌面应用&#xff1f; 选择 .NET 6&#xff08;最早称为 .NET Core&#xff09;而非 Frameworks.NET 的理由是&#xff1a;&#xff08;1&#xff09;跨平台&#xff1b;已经支持Windows,Linux…

PyQt基础_008_ 按钮类控件QSpinbox

基本操作 import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import *class spindemo(QWidget):def __init__(self, parentNone):super(spindemo, self).__init__(parent)self.setWindowTitle("SpinBox 例子")self.resize(300,…