首页 > 其他分享 >HTML和CSS基础(二)

HTML和CSS基础(二)

时间:2024-06-17 19:28:42浏览次数:35  
标签:浮动 flex 右边 布局 字体大小 元素 基础 HTML CSS

四、HTML布局

4.1文档流

HTML文档流(Document Flow)是网页布局的基础,它决定了元素如何在页面上排列。文档流可以分为两大类:正常流(Normal Flow)和脱离正常流(OutOfFlow)。下面详细介绍这两大类以及它们的子分类:

1. 正常流(Normal Flow)

正常流是文档流的默认布局方式,元素按照它们在HTML文档中的顺序排列。正常流可以分为以下子分类:

  • 块级元素(Block-level elements):
    • 总是开始于新行,并且其宽度默认填满父元素的宽度(除非指定宽度)。
    • 高度如果不设置是默认由子元素的高度决定的,但是这种情况是子元素是脱离正常流。
    • 例子: <div>, <p>, <h1> 到 <h6>, <hr>, <ul>, <ol>, <li> 等。
  • 内联元素(Inline elements):
    • 不会开始新行,而是在当前行上水平排列,其宽度根据内容自动调整。
    • 例子: <span>, <a>, <strong>, <em>, <img> 等。
  • 内联块级元素(Inline-block elements):
    • 表现类似于内联元素,但是可以设置宽度和高度。
    • 例子:当display属性设置为inline-block时,如 <div style=“display: inline-block;”>。

2. 脱离正常流(OutOfFlow)

脱离正常流的元素不再遵循正常文档流的布局规则,它们的位置和尺寸可以通过其他CSS属性如float, position等来控制。脱离正常流的布局方式包括:

  • 浮动元素(Floats):

    • 通过float属性(如float: left;或float: right;)使元素脱离文档流,并向左或向右浮动。
    • 浮动元素仍然保留在文本流中,这意味着文本和其他内联元素可以环绕它们。
  • 绝对定位元素(Absolutely positioned elements):

    • 使用position: absolute;或position: fixed;属性,元素的位置相对于其最近的已定位(非 static)祖先元素或- - 视口来定位。
    • 绝对定位的元素完全脱离文档流,不占据空间,因此不会影响其他元素的布局。
  • 相对定位元素(Relatively positioned elements)

    • 使用position: relative;属性,元素相对于其正常位置进行偏移,但保持在文档流中。
    • 相对定位的元素仍然占据原来的空间,影响其他元素的布局。
  • 粘性定位元素(Sticky positioned elements):

    • 使用position: sticky;属性,元素在跨越特定阈值前表现得像相对定位,之后表现得像固定定位。
    • 粘性定位结合了相对定位和固定定位的特点。
  • 表格布局元素(Table elements):

    • 表元素(如<table>, <tr>, <td>等)使用表格模型布局,它们在文档流中表现为块级元素,但内部使用表格布局规则。

4.2float多栏布局

float和clear属性是CSS中用于控制布局的重要工具,它们允许开发者创建多列布局和处理元素的浮动。以下是float和clear属性的工作原理:

float属性

  • 脱离文档流:

    • 当元素应用了float属性(如float: left;或float: right;),它将脱离正常的文档流,并沿着其指定的方向(左或右)浮动。
  • 文本环绕:

    • 浮动元素周围的内联元素(如文本)会尝试环绕该浮动元素,填充其旁边的空间。
  • 元素对齐:

    • 浮动元素可以移动到其包含块的左边缘或右边缘,直到它碰到另一个浮动元素或包含块的边缘。
  • 宽度调整:

    • 浮动元素的宽度可以被指定,但它会尽可能地收缩以适应内容,除非指定了宽度。
  • 清除浮动:

    • 浮动元素可能会导致其他元素(尤其是块级元素)不能正常显示在其下方,因此需要使用clear属性来处理。

clear属性

  • 清除浮动:
    • clear属性用于阻止元素旁边的浮动,确保元素在浮动元素下面开始,而不是旁边。
  • 可选值:
    • clear属性可以设置为left、right、both或none:
    • left:清除左侧的浮动。
    • right:清除右侧的浮动。
    • both:清除左右两侧的所有浮动。
    • none:不清除任何浮动(默认值)。
  • 防止高度塌陷:
    • 在包含浮动元素的块级元素中使用clear,可以防止父元素的高度塌陷,确保父元素能够包含其浮动子元素。
  • 创建新行:
    • 应用了clear属性的元素会创建新的文本流行,即它下方不会有其他浮动元素。
  • 结合使用:
    • 通常在包含浮动元素的容器之后使用一个具有clear: both;的空元素或伪元素(例如::after),以确保容器高度正确。

float创建多栏布局方法

在使用float做多栏布局时,因为布局的子元素div脱离了文档流,如果不给父元素div设置高度,根据块级元素的特点,脱离文档流的子元素不能支撑它的高度,它的高度变为零。
这个时候为了不让父元素高度坍塌有以下两个办法:

  1. 使用清除浮动的元素(Clearfix):
    • 这是一种传统方法,通过在父元素内部的最后一个浮动元素后添加一个具有clear: both;属性的元素来清除浮动。
 <!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>多栏布局示例</title>
  <style>
    .container {
      border: 1px solid black;
      background: green;
    }
    .container2 {
      height: 100px;
      border: 1px solid black;
      background: orange;
    }

    .column {
      float: left;
      /* 浮动到左侧 */
    }

    .left-column {
      width: 30%;
      /* 第一列宽度 */
      background-color: red;
    }

    .middle-column {
      width: 40%;
      /* 第二列宽度 */
      background-color: yellow;
    }

    .right-column {
      width: 30%;
      /* 第三列宽度 */
      background-color: blue;
    }
    .clear-float {
      display: block;
      clear: both;
    }
  </style>
</head>
<body>
  <div class="container">
    <div class="column left-column">
      我是左边栏
    </div>
    <div class="column middle-column">
      我是中间栏

    </div>
    <div class="column right-column">
      我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏
    </div>
    <div class="clear-float"></div>
  </div>
  <div class="container2"></div>
</body>
</html>
  1. 使用overflow属性:
    • 给父元素设置overflow属性为hidden或auto,这可以创建包含浮动元素的块级格式化上下文(BFC),防止高度塌陷。
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>多栏布局示例</title>
  <style>
    .container {
      border: 1px solid black;
      background: green;
      /* 清除浮动 */
      overflow:auto;
    }
    .container2 {
      height: 100px;
      border: 1px solid black;
      background: orange;
    }

    .column {
      float: left;
      /* 浮动到左侧 */
    }

    .left-column {
      width: 30%;
      /* 第一列宽度 */
      background-color: red;
    }

    .middle-column {
      width: 40%;
      /* 第二列宽度 */
      background-color: yellow;
    }

    .right-column {
      width: 30%;
      /* 第三列宽度 */
      background-color: blue;
    }

  </style>
</head>
<body>
  <div class="container">
    <div class="column left-column">
      我是左边栏
    </div>
    <div class="column middle-column">
      我是中间栏
    </div>
    <div class="column right-column">
      我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏我是右边栏
    </div>

  </div>
  <div class="container2"></div>
</body>
</html>

说明: 在HTML4的时代还没有flex布局,那时的网站通常用float来做多栏布局。

4.3flex布局

Flex布局,全称为Flexible Box Layout,是一种用于网页布局的CSS3规范,提供了一种更加高效和灵活的方式来处理一维布局模型(水平或垂直)。Flex布局可以轻松地分配空间、对齐和排列容器内的元素,即使它们的大小未知或是动态变化的。

Flex布局的关键概念:

1. 容器和项目:

使用display: flex;或display: inline-flex;属性将一个容器定义为Flex容器,其直接子元素成为Flex项目。

2.主轴和交叉轴:

Flex容器有两个轴:主轴(main axis)和交叉轴(cross axis)。主轴的默认方向是行(row),可以水平或垂直排列项目。交叉轴垂直于主轴。

3.flex-direction:

用于设置主轴的方向,可以是row、row-reverse、column、column-reverse。

4.justify-content:

用于沿主轴对齐项目,可选值包括flex-start、flex-end、center、space-between、space-around、space-evenly。

5.align-items:

用于在交叉轴上对齐项目,可选值包括flex-start、flex-end、center、baseline、stretch。

6.align-content:

用于在交叉轴上对多行项目进行对齐,当项目数量超过一行时使用,可选值类似于justify-content。

7.flex-grow:

定义项目放大比例,当容器有多余空间时,项目可以扩展。

8.flex-shrink:

定义项目缩小比例,当容器空间不足时,项目可以缩小。

9.flex-basis:

定义项目在主轴上的初始大小。

9. flex:

flex属性是flex-grow、flex-shrink、flex-basis的简写,默认值为0 1 auto。

flex布局在大神阮一峰的博客中图文并茂图文并茂的细致讲解,各位可以移步去学习。

4.4元素居中对齐

在HTML布局中,让子元素在父元素中上下左右居中对齐是一个常见需求。可以使用多种方法来实现这一目标,以下是几种常见的方式:

1. 使用Flexbox

Flexbox是一种强大的布局工具,可以很容易地实现子元素在父元素中的居中对齐。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .parent {
      display: flex;
      justify-content: center; /* 水平居中 */
      align-items: center; /* 垂直居中 */
      height: 200px;
      border: 1px solid black;
    }
    .child {
      width: 100px;
      height: 100px;
      background-color: lightblue;
    }
  </style>
</head>
<body>
  <div class="parent">
    <div class="child"></div>
  </div>
</body>
</html>

2. 使用Grid布局

CSS Grid布局也是一种非常强大的布局方式,可以轻松实现子元素的居中对齐。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .parent {
      display: grid;
      place-items: center; /* 同时水平和垂直居中 */
      height: 200px;
      border: 1px solid black;
    }
    .child {
      width: 100px;
      height: 100px;
      background-color: lightgreen;
    }
  </style>
</head>
<body>
  <div class="parent">
    <div class="child"></div>
  </div>
</body>
</html>

3. 使用定位(Positioning)

可以使用 position 属性结合 top, right, bottom, left 和 transform 属性来实现居中对齐。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .parent {
      position: relative;
      height: 200px;
      border: 1px solid black;
    }
    .child {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 100px;
      height: 100px;
      background-color: lightcoral;
    }
  </style>
</head>
<body>
  <div class="parent">
    <div class="child"></div>
  </div>
</body>
</html>

4. 使用表格布局(Table Layout)

可以使用 CSS 的 display: table 和 display: table-cell 属性来实现居中对齐。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .parent {
      display: table;
      height: 200px;
      width: 200px;
      border: 1px solid black;
    }
    .child {
      display: table-cell;
      vertical-align: middle; /* 垂直居中 */
      text-align: center; /* 水平居中 */
      width: 100px;
      height: 100px;
      background-color: lightseagreen;
      margin: auto;
    }
  </style>
</head>
<body>
  <div class="parent">
    <div class="child">Centered</div>
  </div>
</body>
</html>

5. 使用行内块元素(Inline-block)

使用 text-align 和 vertical-align 属性也可以实现子元素的居中对齐。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .parent {
      text-align: center; /* 水平居中 */
      height: 200px;
      border: 1px solid black;
      display: table-cell;
      vertical-align: middle; /* 垂直居中 */
    }
    .child {
      display: inline-block;
      width: 100px;
      height: 100px;
      background-color: lightgoldenrodyellow;
    }
  </style>
</head>
<body>
  <div class="parent">
    <div class="child"></div>
  </div>
</body>
</html>

五、响应式设计

在HTML5中,控制字体大小随屏幕变化而变动,主要是通过CSS实现响应式设计。以下是一些常用的方法:

1.使用相对单位:

使用相对单位(如em、rem、%)而不是绝对单位(如px)来设置字体大小。这样,字体大小就可以根据其父元素或根元素的字体大小进行缩放。

body {
  font-size: 100%; /* 相对于根元素的字体大小 */
}
h1 {
  font-size: 2rem; /* 相对于body元素的字体大小 */
}

2.媒体查询(Media Queries):

使用CSS媒体查询根据不同的屏幕尺寸或设备特性应用不同的样式规则。

/* 基础样式 */
body {
  font-size: 16px;
}

/* 当屏幕宽度大于600px时 */
@media (min-width: 600px) {
  body {
    font-size: 18px;
  }
}

/* 当屏幕宽度大于900px时 */
@media (min-width: 900px) {
  body {
    font-size: 20px;
  }
}

3.Viewport单位:

使用vw(视口宽度的百分比)或vh(视口高度的百分比)单位来设置字体大小,使字体大小与视口大小成比例。

body {
  font-size: 2vw; /* 视口宽度的2% */
}

4.CSS Clamp函数:

clamp()函数可以根据视口大小在指定的范围内调整字体大小,它接受三个参数:最小值、首选值和最大值。

body {
  font-size: clamp(1rem, 2vw, 2rem);
}
响应式字体大小的JavaScript解决方案:
使用JavaScript根据屏幕宽度动态调整字体大小。

function responsiveFont() {
  const minSize = 12; // 最小字体大小
  const maxSize = 24; // 最大字体大小
  const currentSize = Math.max(minSize, Math.min(window.innerWidth / 100, maxSize)); // 根据屏幕宽度计算字体大小
  document.body.style.fontSize = `${currentSize}px`;
}

// 初始化响应式字体大小
responsiveFont();
// 监听窗口大小变化
window.addEventListener('resize', responsiveFont);

5.使用CSS环境变量:

使用CSS自定义属性(CSS环境变量)来控制字体大小,然后在媒体查询中调整这些变量的值。

:root {
  --font-size: 16px;
}

body {
  font-size: var(--font-size);
}

@media (min-width: 600px) {
  :root {
    --font-size: 18px;
  }
}

这些方法可以单独使用,也可以组合使用,以实现更精细的控制。在设计响应式网页时,目标是确保在不同设备和屏幕尺寸上都能提供良好的可读性和用户体验。

标签:浮动,flex,右边,布局,字体大小,元素,基础,HTML,CSS
From: https://blog.csdn.net/way311/article/details/139740672

相关文章

  • 【cv-python基础】不同数据集的解析
    前言数据集使用之前需要对标注文件进行解析,故此记录。代码实现1.APA数据集解析#20240612:parsejsonfiletolabeledimage.importargparseimportjsonimportosimportos.pathasospimportcv2ascvimportnumpyasnpjsonfilename="freespace_3Dbox_APA.j......
  • 【CV基础】理解woodscape数据集
    前言最近需要用到鱼眼图像做语义分割、目标检测等任务,最开始先使用woodscape数据集进行训练、测试,故此记录学习woodscape数据集。学习woodscape数据集1.随机划分数据集shell脚本#!/bin/sh#20240617:splitwoodscapedatasetof10classesrandomlybasedoncityscape......
  • 【AI开发】RAG基础
    RAG的基本流程:用一个loader把knowledgebase里的知识做成一个个的document,然后把document切分成snippets,把snippets通过embedding(比如openai的embedding模型或者huggingface的)向量化,存储到vectordb向量数据库,以供后续相关性检索。至此便完成了私域数据集的索引indexing。......
  • Sass和传统CSS有什么区别?
    Sass(SyntacticallyAwesomeStylesheets)与传统CSS在功能和语法上有一些显著的区别。以下是Sass相比传统CSS的一些关键优势和区别:变量(Variables):Sass允许使用变量存储信息,如颜色、字体大小等,以便在样式表中重复使用。这在传统CSS中是不可能的。$primary-color:#3498db;$......
  • 现在做一个圈子系统的优势,圈子系统基础玩法
    优势圈子是一个万能的信息聚合模型,可以复制扩展成各种商圈、黄页、部落、学校、家族等等,也有附近的圈子功能。这几年最火的是什么.就是微信群.但是现在群信群暴露出来的诸多的问题第一,里边信息混乱,虽然当时可以很方便的讨论一个话题,但是过后,别人不方便再继续讨论这个......
  • html2canvas插件 线上image转base64
    UncaughtDOMException:Failedtoexecute'toDataURL'on'HTMLCanvasElement':Taintedcanvasesmaynotbeexported.html2canvas,如果html中有image,需要转base64才能正常转换image。本地调试可能存在跨域访问图片问题。由于图片服务器未开启跨域允许权限。Access-Control-A......
  • WordPress基础之主题和插件安装
    本篇文章学习WordPress如何安装主题、插件。同时推荐几个我常用的主题、插件及其设置方法。WordPress有海量的主题和插件,有付费的,也有免费的。每个主题都有自己的优缺点,当然,你可以在WP测试站上随意的安装删除主题,直到确定好网站的整体风格后再安装到正式网站中。1.WordPress主......
  • WordPress基础之基本SEO设置
    基础内容,不会涉及过深,在谷歌SEO教程中会做详细的介绍,我这里只简单讲下。1.SEO介绍SEO,又名搜索引擎优化(SearchEngineOptimization,缩写为SEO)是透过了解搜索引擎的运作规则来调整网站,以及提高网站在搜索引擎内排名的方式。2.SEO基础三要素基础SEO有三大基本要素:标题、描述、......
  • 4种CSS实现全屏背景图片铺满自适应的方式,最后一种尤其简单
    在Web设计中,背景图片是提升页面视觉效果的重要元素。实现背景图片全屏铺满且自适应是常见的需求。本文将介绍三种CSS技术,用以确保背景图片能够优雅地填充整个屏幕并适应不同设备。方式一:使用background-size属性CSS的background-size属性可以设置背景图片的尺寸,使其覆盖整个......
  • aardio实战篇) 下载微信公众号文章为pdf和html
    首发地址:https://mp.weixin.qq.com/s/w6v3RhqN0hJlWYlqTzGCxA前言之前在PC微信逆向)定位微信浏览器打开链接的call提过要写一个保存公众号历史文章的工具。这篇文章先写一个将文章保存成pdf和html的工具,后面再补充一个采集历史的工具,搭配使用就能保存所有历史文章到本地。如......