CSS基础-CSS引入、规范、调试、选择器

165 阅读7分钟

✊不积跬步,无以至千里;不积小流,无以成江海

之前写过的笔记链接:

[起源/语法/基本调试方法/调试大法](📝 CSS入门笔记1 (yuque.com))

CSS引入方式,书写规范、调试方法

CSS引入方式

在 HTML 中引入 CSS 样式表有多种方式,以下是常见的 CSS 引入方式:

  1. 内联样式(Inline Styles) :在 HTML 元素的 style 属性中直接定义样式。例如:
<div style="color: blue; font-size: 16px;">这是一个文本块</div>

内联样式是针对具体元素的样式,适用于一些简单的样式定义,但不适合大规模应用于整个网站或应用程序。

  1. 嵌入样式(Embedded Styles) :使用 <style> 标签将 CSS 样式直接嵌入到 HTML 页面的 <head> 部分。例如:
<head>
  <style>
    .text-block {
      color: blue;
      font-size: 16px;
    }
  </style>
</head>
<body>
  <div class="text-block">这是一个文本块</div>
</body>

嵌入样式适用于页面特定的样式定义,但对于全局样式和样式重用性较差。

  1. 外部样式表(External Stylesheet) :将 CSS 样式定义在一个单独的外部 CSS 文件中,并通过 <link> 标签将其引入到 HTML 页面中。例如:
<head>
  <link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
  <div class="text-block">这是一个文本块</div>
</body>

在外部样式表中,可以定义全局样式和大规模应用于整个网站或应用程序的样式,并通过多个 HTML 页面共享同一个样式文件,提高代码的可维护性和重用性。

使用外部样式表是最常见且推荐的 CSS 引入方式,可以将样式和内容分离,使代码更清晰、易于维护,并提供更好的可扩展性。

CSS书写规范

编写规范的 CSS 代码可以提高代码的可读性、可维护性和协作效率。以下是一些常见的 CSS 书写规范:

  1. 缩进和空格

    • 使用 2 或 4 个空格进行缩进,避免使用制表符。
    • 在选择器、属性和值之间使用一个空格,例如:.selector { color: blue; }
    • 在属性的冒号后面使用一个空格,例如:color: blue;
  2. 选择器命名

    • 使用有意义的、描述性的选择器命名,避免使用无意义的缩写或单个字母作为选择器。
    • 使用连字符(短横线)分隔多个单词的选择器命名,例如:.header-section
    • 避免选择器嵌套层级过深,以减少选择器的复杂性。
  3. 注释

    • 使用注释来解释代码的意图、用途和特殊考虑事项。
    • 使用适当的注释划分代码块,可以按模块、组件或功能进行注释。
  4. 样式属性顺序

    • 按照特定的顺序编写样式属性,例如:布局相关属性(如 displayposition)在前,然后是盒模型属性(如 widthheight),最后是视觉效果属性(如 colorbackground)。
    • 统一属性的书写顺序可以提高代码的一致性和可读性。
  5. 简写属性

    • 对于可以简写的属性(如 marginpaddingfont),尽量使用简写形式,以减少代码量和提高可读性。
  6. 单位

    • 使用相对单位(如 emrem)来实现响应式布局和可伸缩性。
    • 对于无单位的零值,省略单位(例如:margin: 0;)。
  7. 避免使用 !important

    • 避免过度使用 !important,它应该作为最后的手段。合理地组织选择器和规则,以避免出现样式冲突。
  8. 组织和结构

    • 根据功能或模块对样式规则进行组织,可以使用注释或空行来划分不同的部分。
    • 使用合理的代码组织方式,例如使用预处理器(如 Sass、Less)或 CSS 模块化工具。

以上是一些常见的 CSS 书写规范,但请注意,具体的规范可能因团队、项目或个人偏好而有所不同。重要的是选择一种适合团队的规范,并在整个项目中保持一致性。

CSS调试方法

在调试 CSS 时,以下是一些常用的方法和技巧:

  1. 使用开发者工具:现代的浏览器都提供了开发者工具,可以帮助调试和查看 CSS。使用开发者工具可以检查元素的样式属性、修改样式实时预览效果,并在调试过程中定位问题。
  2. 验证 CSS 语法:使用 CSS 验证工具(如 W3C CSS 验证器)检查 CSS 文件的语法错误。这有助于发现并纠正潜在的语法问题。
  3. 逐步删除或注释代码:如果遇到 CSS 样式不生效或产生意外效果的问题,可以逐步删除或注释部分代码,以确定问题出现的具体位置。这有助于缩小范围并找到问题所在。
  4. 使用边框和背景色:通过为元素添加临时边框或背景色来可视化元素的边界和位置。这可以帮助确认元素是否正确选择,并检查布局问题。
  5. 使用 outline 属性:将 outline 属性应用于元素,以显示元素的轮廓线。这对于检查元素之间的间距、边界和定位非常有用。
  6. 添加临时样式:通过在开发者工具中为元素添加临时样式,可以实时预览样式的效果。这对于尝试不同的样式属性或值以解决问题很有帮助。
  7. 检查样式优先级:当多个 CSS 规则应用于同一个元素时,样式优先级可能导致冲突或不符预期的结果。使用开发者工具查看应用于元素的样式规则及其优先级,并确保所需的样式得到正确应用。
  8. 重置或清除样式:有时,其他 CSS 规则或浏览器默认样式可能干扰了所需样式的应用。使用 CSS 重置或清除样式表来消除这些干扰,并确保从一个干净的起点开始构建样式。
  9. 使用浏览器兼容性工具:在编写 CSS 时,可以使用浏览器兼容性工具(如 Can I Use、Autoprefixer)来检查 CSS 属性和值的兼容性,并自动添加适当的前缀。
  10. 查找文档和资源:如果遇到特定的 CSS 问题,查找相关的文档、教程或在线资源(如 MDN Web Docs、Stack Overflow)可能会提供有关问题的解决方案或提示。

几种选择器用法

在 CSS 中,有多种选择器可以用来选择 HTML 元素并应用样式。以下是几种常见的 CSS 选择器及其用法的解释:

  1. 元素选择器(Element Selector):使用元素名称作为选择器来选择匹配的 HTML 元素。例如,选择所有的段落元素:
p {
  /* 样式规则 */
}

这将选择 HTML 中的所有 <p> 元素,并应用样式规则。

  1. 类选择器(Class Selector):使用类名作为选择器来选择具有相同类的元素。类选择器以点号(.)开头,后面跟着类名。例如,选择具有 "highlight" 类的元素:
.highlight {
  /* 样式规则 */
}

在 HTML 中,将 class 属性设置为 "highlight" 的元素将应用这些样式规则。

  1. ID 选择器(ID Selector):使用元素的唯一 ID 来选择特定元素。ID 选择器以井号(#)开头,后面跟着元素的 ID。例如,选择 ID 为 "header" 的元素:
#header {
  /* 样式规则 */
}

在 HTML 中,将 id 属性设置为 "header" 的元素将应用这些样式规则。

  1. 后代选择器(Descendant Selector):通过指定元素的祖先和后代关系来选择元素。后代选择器使用空格分隔选择器。例如,选择 div 元素内部的所有 p 元素:
div p {
  /* 样式规则 */
}

这将选择 div 元素内部的所有直接或间接后代 p 元素。

  1. 子元素选择器(Child Selector):通过指定元素的父元素和子元素关系来选择元素。子元素选择器使用大于号(>)分隔选择器。例如,选择 div 元素的直接子元素 p
div > p {
  /* 样式规则 */
}

这将选择 div 元素的直接子元素中的 p 元素。

  1. 相邻兄弟选择器(Adjacent Sibling Selector):通过选择元素的相邻兄弟元素来选择元素。相邻兄弟选择器使用加号(+)分隔选择器。例如,选择 h2 元素后紧接着的相邻 p 元素:
h2 + p {
  /* 样式规则 */
}

这将选择紧跟在 h2 元素后面的相邻 p 元素。