CSS3 基础布局技术与响应式设计

1. CSS3 基础与布局技术

1.1 Flexbox 布局

Flexbox 是一种一维布局模型,适合用于在一个方向上(行或列)排列元素。

基本概念:

  • 容器(Container):应用 display: flex; 的元素。
  • 项目(Item):容器内的子元素。

常用属性:

  • 容器属性:

    • display: flex;:将容器设置为 Flexbox 布局。
    • flex-direction: row | row-reverse | column | column-reverse;:定义主轴方向。
    • justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;:定义项目在主轴上的对齐方式。
    • align-items: flex-start | flex-end | center | baseline | stretch;:定义项目在交叉轴上的对齐方式。
    • flex-wrap: nowrap | wrap | wrap-reverse;:定义项目是否换行。
  • 项目属性:

    • flex: <grow> <shrink> <basis>;:定义项目的伸缩性。
    • align-self: auto | flex-start | flex-end | center | baseline | stretch;:定义单个项目在交叉轴上的对齐方式。

示例代码:

<div class="flex-container"><div class="item">1</div><div class="item">2</div><div class="item">3</div>
</div>
.flex-container {display: flex;justify-content: space-between;align-items: center;height: 200px;background-color: #f4f4f4;
}.item {background-color: #ccc;padding: 20px;margin: 5px;
}

解释:

  • .flex-container 是 Flexbox 容器,display: flex; 启用了 Flexbox 布局。
  • justify-content: space-between; 让项目在主轴上均匀分布,两端对齐。
  • align-items: center; 让项目在交叉轴上居中对齐。
1.2 Grid 布局

Grid 是一种二维布局模型,适合用于在行和列两个方向上进行布局。

基本概念:

  • 容器(Container):应用 display: grid; 的元素。
  • 项目(Item):容器内的子元素。

常用属性:

  • 容器属性:

    • display: grid;:将容器设置为 Grid 布局。
    • grid-template-columns: <track-size> ...;:定义列的大小。
    • grid-template-rows: <track-size> ...;:定义行的大小。
    • gap: <row-gap> <column-gap>;:定义行和列之间的间隙。
    • justify-items: start | end | center | stretch;:定义项目在单元格内的水平对齐方式。
    • align-items: start | end | center | stretch;:定义项目在单元格内的垂直对齐方式。
  • 项目属性:

    • grid-column: <start> / <end>;:定义项目占据的列。
    • grid-row: <start> / <end>;:定义项目占据的行。
    • justify-self: start | end | center | stretch;:定义单个项目在单元格内的水平对齐方式。
    • align-self: start | end | center | stretch;:定义单个项目在单元格内的垂直对齐方式。

示例代码:

<div class="grid-container"><div class="item">1</div><div class="item">2</div><div class="item">3</div><div class="item">4</div><div class="item">5</div><div class="item">6</div>
</div>
.grid-container {display: grid;grid-template-columns: repeat(3, 1fr);grid-template-rows: repeat(2, 100px);gap: 10px;background-color: #f4f4f4;
}.item {background-color: #ccc;padding: 20px;text-align: center;
}

解释:

  • .grid-container 是 Grid 容器,display: grid; 启用了 Grid 布局。
  • grid-template-columns: repeat(3, 1fr); 定义了三列,每列的宽度相等。
  • grid-template-rows: repeat(2, 100px); 定义了两行,每行的高度为 100px。
  • gap: 10px; 定义了行和列之间的间隙为 10px。

2. 响应式设计

2.1 媒体查询(Media Queries)

媒体查询允许你根据设备的特性(如屏幕宽度、高度等)应用不同的样式。

基本语法:

@media (条件) {/* 满足条件时应用的样式 */
}

常用条件:

  • max-width:最大宽度。
  • min-width:最小宽度。
  • orientation: portrait | landscape;:设备方向。

示例代码:

/* 默认样式 */
body {background-color: lightblue;
}/* 当屏幕宽度小于等于 600px 时应用的样式 */
@media (max-width: 600px) {body {background-color: lightcoral;}
}/* 当屏幕宽度大于 600px 且小于等于 900px 时应用的样式 */
@media (min-width: 601px) and (max-width: 900px) {body {background-color: lightgreen;}
}

解释:

  • max-width: 600px; 当屏幕宽度小于等于 600px 时,背景颜色变为 lightcoral
  • min-width: 601px 和 max-width: 900px 当屏幕宽度在 601px 到 900px 之间时,背景颜色变为 lightgreen
2.2 移动优先(Mobile First)

移动优先是一种设计理念,首先为移动设备设计样式,然后通过媒体查询逐步增强为大屏幕设备的样式。

示例代码:

/* 移动设备样式 */
body {background-color: lightblue;font-size: 14px;
}/* 平板设备样式 */
@media (min-width: 600px) {body {font-size: 16px;}
}/* 桌面设备样式 */
@media (min-width: 900px) {body {font-size: 18px;}
}

解释:

  • 默认样式是为移动设备设计的,背景颜色为 lightblue,字体大小为 14px
  • 当屏幕宽度大于等于 600px 时,字体大小变为 16px
  • 当屏幕宽度大于等于 900px 时,字体大小变为 18px

3. 综合示例

以下是一个结合 Flexbox、Grid 和响应式设计的综合示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Responsive Layout</title><style>/* 移动设备样式 */body {font-family: Arial, sans-serif;margin: 0;padding: 0;background-color: #f4f4f4;}.container {display: grid;grid-template-columns: 1fr;gap: 10px;padding: 10px;}.header, .footer {background-color: #333;color: white;text-align: center;padding: 10px;}.nav {display: flex;justify-content: space-around;background-color: #444;padding: 10px;}.nav a {color: white;text-decoration: none;}.main {background-color: white;padding: 10px;}/* 平板设备样式 */@media (min-width: 600px) {.container {grid-template-columns: 1fr 3fr;}.nav {flex-direction: column;justify-content: flex-start;}.nav a {margin: 5px 0;}}/* 桌面设备样式 */@media (min-width: 900px) {.container {grid-template-columns: 1fr 3fr;}.main {display: grid;grid-template-columns: repeat(2, 1fr);gap: 10px;}}</style>
</head>
<body><div class="container"><header class="header"><h1>Header</h1></header><nav class="nav"><a href="#">Home</a><a href="#">About</a><a href="#">Services</a><a href="#">Contact</a></nav><main class="main"><section><h2>Section 1</h2><p>Content of section 1.</p></section><section><h2>Section 2</h2><p>Content of section 2.</p></section></main><footer class="footer"><p>Footer</p></footer></div>
</body>
</html>

解释: ½ 默认样式是为移动设备设计的,使用单列布局。

  • 当屏幕宽度大于等于 600px 时,使用双列布局,导航栏变为垂直排列。
  • 当屏幕宽度大于等于 900px 时,主内容区域使用双列布局。

总结

  • Flexbox 适合一维布局,Grid 适合二维布局。
  • 媒体查询 允许你根据设备特性应用不同的样式,移动优先 是一种设计理念,首先为移动设备设计样式,然后逐步增强为大屏幕设备的样式。

 

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

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

相关文章

鸿蒙NEXT项目实战-百得知识库01

代码仓地址&#xff0c;大家记得点个star IbestKnowTeach: 百得知识库基于鸿蒙NEXT稳定版实现的一款企业级开发项目案例。 本案例涉及到多个鸿蒙相关技术知识点&#xff1a; 1、布局 2、配置文件 3、组件的封装和使用 4、路由的使用 5、请求响应拦截器的封装 6、位置服务 7、三…

【DeepSeek应用】本地部署deepseek模型后,如何在vscode中调用该模型进行代码撰写,检视和优化?

若已成功在本地部署了 DeepSeek 模型(例如通过 vscode-llm、ollama 或私有 API 服务),在 VS Code 中调用本地模型进行代码撰写、检视和优化的完整流程如下: 1. 准备工作:确认本地模型服务状态 模型服务类型: 若使用 HTTP API 服务(如 FastAPI/Flask 封装),假设服务地址…

jenkins 配置邮件问题整理

版本&#xff1a;Jenkins 2.492.1 插件&#xff1a; A.jenkins自带的&#xff0c; B.安装功能强大的插件 配置流程&#xff1a; 1. jenkins->系统配置->Jenkins Location 此处的”系统管理员邮件地址“&#xff0c;是配置之后发件人的email。 2.配置系统自带的邮件A…

Android Coil3阶梯preload批量Bitmap拼接扁平宽图,Kotlin

Android Coil3阶梯preload批量Bitmap拼接扁平宽图&#xff0c;Kotlin <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name"android.permission.READ_EXTERNAL_STORAGE" /><uses-p…

C++基础 [八] - list的使用与模拟实现

目录 list的介绍 List的迭代器失效问题 List中sort的效率测试 list 容器的模拟实现思想 模块分析 作用分析 list_node类设计 list 的迭代器类设计 迭代器类--存在的意义 迭代器类--模拟实现 模板参数 和 成员变量 构造函数 * 运算符的重载 运算符的重载 -- 运…

【系统架构设计师】操作系统 - 特殊操作系统 ③ ( 微内核操作系统 | 单体内核 操作系统 | 内核态 | 用户态 | 单体内核 与 微内核 对比 )

文章目录 一、微内核操作系统1、单体内核 操作系统2、微内核操作系统 引入3、微内核操作系统 概念4、微内核操作系统 案例 二、单体内核 与 微内核 对比1、功能对比2、单体内核 优缺点3、微内核 优缺点 一、微内核操作系统 1、单体内核 操作系统 单体内核 操作系统 工作状态 : …

系统思考:恶性循环

去年&#xff0c;我给一家知名人力资源公司交付了两个项目——一个在6月&#xff0c;另一个在8月&#xff0c;至今半年多了依然没有收到课酬。催促多次&#xff0c;得到的答复却各式各样&#xff1a;销售说老板卡了额度&#xff0c;老板说具体情况还需了解。每一次的推诿&#…

基于springboot的房屋租赁系统(008)

摘 要 社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱&#xff0c;也逐渐进入了每个用户的使用。互联网具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本低等优点。 因此&#xff0c;构建符…

视频翻译器免费哪个好?轻松玩转视频直播翻译

你是不是觉得看外语视频很麻烦&#xff1f;每次遇到喜欢的外语电影、电视剧或动漫&#xff0c;总是要等字幕组的翻译&#xff0c;或者因为语言不通而错过精彩的情节。 这个时候&#xff0c;掌握多语种直播翻译方案就显得尤为重要&#xff0c;有了实时字幕&#xff0c;看外语视…

在cherry studio中使用MCP——本地文件管理FileSystem

cherry studio是一款开源的AI助手工具&#xff0c;可以便捷地利用API访问各种LLM&#xff0c;有关cherry studio的使用这里不再多说&#xff0c;可以参考这篇文章https://blog.csdn.net/m0_65494437/article/details/145478823 官网&#xff1a;https://cherry-ai.com/ MCP是什…

从点灯开始的51单片机生活

陵谷纷纭新事改&#xff0c;筑台土石未应迟。 目录 sfr与sbit&#xff1f;不靠定时器的delay_ms延时函数所谓寄存器 sfr与sbit&#xff1f; 这第一课咱们主要来先理解一下sfr与sbit&#xff0c;以下可能是咱们这些新手朋友常见的点灯代码&#xff1a; #include<regx52.h&g…

Django系列教程(13)——Cookie和Session应用场景及案例

目录 什么是cookie&#xff0c;cookie的应用场景及缺点 Django中如何使用cookie Cookie使用示例 什么是session及session的工作原理 Django中如何使用会话session Session使用示例 小结 HTTP协议本身是”无状态”的&#xff0c;在一次请求和下一次请求之间没有任何状态保…

c++类和对象(下篇)下

下面就来补充一下c雷和对象最后一点内容. 首先先补充一下上一篇博客上c类和对象(下篇)上-CSDN博客最后学习的静态成员变量的小练习求123...n_牛客题霸_牛客网 (nowcoder.com)下面就是题解.灵活的运用了静态成员变量不销毁的特点,建立数组利用构造函数来完成n次相加. class A{ …

《TCP/IP网络编程》学习笔记 | Chapter 19:Windows 平台下线程的使用

《TCP/IP网络编程》学习笔记 | Chapter 19&#xff1a;Windows 平台下线程的使用 《TCP/IP网络编程》学习笔记 | Chapter 19&#xff1a;Windows 平台下线程的使用内核对象内核对象的定义内核对象归操作系统所有 基于 Windows 的线程创建进程与线程的关系Windows 中线程的创建方…

分布式事务解决方案:Seata原理详解与实战教程

一、为什么需要Seata&#xff1f; 在微服务架构中&#xff0c;跨服务的事务管理成为核心痛点&#xff1a; 传统事务失效&#xff1a;服务拆分导致无法使用本地事务数据不一致风险&#xff1a;网络抖动、服务宕机等情况导致数据错乱复杂场景处理难&#xff1a;涉及多个数据库、…

docker需要sudo才能使用

一种方法是添加当前用户到docker组里去&#xff0c;当时添加的时候貌似是没问题的&#xff0c;但是现在又不可以了 产生的报错 ❯ docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解决…

学习记录 6 pointnet复现

一、复现代码 然后去找相关的2d的声呐图像分类的算法 融合可以搞的&#xff0c;虽然有文献但是不多&#xff0c;感觉也是可以的 """ Author: Benny Date: Nov 2019 """import os import sys import torch import numpy as npimport datetime …

Linux 文件操作-标准IO函数3- fread读取、fwrite写入、 fprintf向文件写入格式化数据、fscanf逐行读取格式化数据的验证

目录 1. fread 从文件中读取数据 1.1 读取次数 每次读取字节数 < 原内容字节数 1.2 读取次数 每次读取字节数 > 原内容字节数 2.fwrite 向文件中写入数据 2.1写入字符串验证 2.2写入结构体验证 3. fprintf 将数据写入到指定文件 4. fscanf 从文件中逐行读取内容…

Python 中下划线 “_” 的多面性:从变量到约定

# Python中下划线“_”的多面性&#xff1a;从变量到约定 在Python的语法体系里&#xff0c;下划线“_”看似毫不起眼&#xff0c;实则扮演着极为重要且多样化的角色。它不仅能作为普通变量参与编程&#xff0c;更在多个特殊场景下有着独特的用途与约定。深入理解下划线的各种…

深入 Linux 声卡驱动开发:核心问题与实战解析

1. 字符设备驱动如何为声卡提供操作接口&#xff1f; 问题背景 在 Linux 系统中&#xff0c;声卡被抽象为字符设备。如何通过代码让应用程序能够访问声卡的录音和播放功能&#xff1f; 核心答案 1.1 字符设备驱动的核心结构 Linux 字符设备驱动通过 file_operations 结构体定…