《CSS 简易速速上手小册》第10章:未来的 CSS(2024 最新版)

news2024/11/24 6:49:08

在这里插入图片描述

文章目录

  • 10.1 CSS 的新特性和趋势
    • 10.1.1 基础知识
    • 10.1.2 重点案例:使用 CSS Grid 创建响应式图库
    • 10.1.3 拓展案例 1:利用 CSS 变量实现主题切换
    • 10.1.4 拓展案例 2:使用 `lab()` 颜色和 `@layer` 规则优化样式
  • 10.2 CSS Houdini:魔法般的 Web 工作线
    • 10.2.1 基础知识
    • 10.2.2 重点案例:使用 Paint API 创建自定义波浪形分隔线
    • 10.2.3 拓展案例 1:利用 Properties and Values API 实现主题切换
    • 10.2.4 拓展案例 2:使用 Layout API 实现瀑布流布局
  • 10.3 构建更加动态和互动的用户界面
    • 10.3.1 基础知识
    • 10.3.2 重点案例:创建一个带有动画的加载指示器
    • 10.3.3 拓展案例 1:使用过渡实现交互式按钮
    • 10.3.4 拓展案例 2:利用滤镜和剪裁路径创建特殊效果

10.1 CSS 的新特性和趋势

随着Web技术的快速发展,CSS也在不断进化,引入了许多新特性和趋势,这些进步不仅提高了开发效率,也大大丰富了Web设计的可能性。让我们一起探索一些引人注目的CSS新特性和正在形成的趋势。

10.1.1 基础知识

  • CSS变量(Custom Properties):允许你在样式表中存储可重用的值,并在整个文档中使用它们。
  • CSS Grid布局:为Web页面提供了一种强大的布局系统,比传统的布局方法更加灵活和强大。
  • Flexbox布局:简化了复杂布局的创建过程,特别适合于一维布局。
  • Subgrid:CSS Grid的扩展,允许grid项(grid item)内部的元素参与到外部grid容器的布局中。
  • @layer规则:最近提出的提案,旨在帮助开发者管理大型和复杂的样式表。
  • 颜色级别4(CSS Color Module Level 4):引入了更多的颜色函数和新颜色空间,如lab()lch()color()函数,提供了更广泛的色彩表达能力。

10.1.2 重点案例:使用 CSS Grid 创建响应式图库

假设你要为一个摄影网站创建一个响应式图库,展示各种摄影作品。

  • HTML 结构
<div class="gallery">
  <div class="photo">...</div>
  <div class="photo">...</div>
  <!-- 更多照片 -->
</div>
  • CSS 样式
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
}

通过使用CSS Grid的auto-fillminmax()函数,你可以创建一个自动适应不同屏幕尺寸的图库布局,无需媒体查询。

10.1.3 拓展案例 1:利用 CSS 变量实现主题切换

为了支持深色模式和浅色模式,你可以使用CSS变量和JavaScript来动态切换网站主题。

  • CSS 样式
:root {
  --primary-color: #333;
  --background-color: #fff;
}

[data-theme="dark"] {
  --primary-color: #ccc;
  --background-color: #222;
}

body {
  color: var(--primary-color);
  background-color: var(--background-color);
}
  • JavaScript
const switchThemeButton = document.getElementById('theme-switcher');
switchThemeButton.addEventListener('click', function() {
  document.body.dataset.theme = document.body.dataset.theme === 'dark' ? 'light' : 'dark';
});

10.1.4 拓展案例 2:使用 lab() 颜色和 @layer 规则优化样式

探索CSS颜色级别4和@layer规则来提升你的样式表的组织和颜色表达。

  • CSS 样式
@layer base {
  :root {
    --primary-color: lab(56% 80 -52);
    --secondary-color: lch(50% 70 270);
  }
}

@layer themes {
  .dark-theme {
    --primary-color: lab(29% 20 -22);
    --secondary-color: lch(30% 40 290);
  }
}

这些案例展示了CSS新特性如何被用来创建更加动态、响应式和色彩丰富的Web界面,同时保持代码的可维护性和组织性。随着CSS的不断发展,我们期待看到更多创新的应用和实践,推动Web设计和开发进入新的时代。

在这里插入图片描述


10.2 CSS Houdini:魔法般的 Web 工作线

CSS Houdini是一组底层API的集合,旨在将CSS的强大能力暴露给开发者,允许他们更直接地访问浏览器的CSS引擎。这意味着开发者可以创建自定义的CSS属性和值,控制布局、绘制等过程,甚至实现之前只能通过JavaScript或不可能实现的视觉效果。

10.2.1 基础知识

  • 工作线概览:CSS Houdini涵盖了几个主要的工作线,包括属性与值API、布局API、绘制API(Paint API)、动画工作线(Animation Worklet)和类型对象模型(Typed OM)。
  • 属性与值API(Properties and Values API):允许开发者定义新的自定义CSS属性,这些属性可以在CSS和JavaScript之间共享。
  • 绘制API(Paint API):使开发者能够通过JavaScript来绘制图像和图形作为CSS背景、边框等。
  • 布局API(Layout API):允许开发者定义自己的布局算法,实现新的布局模式。

10.2.2 重点案例:使用 Paint API 创建自定义波浪形分隔线

假设你想在一个网页上实现一个具有动态波浪形分隔线的视觉效果。

  • 注册工作线
if ('paintWorklet' in CSS) {
  CSS.paintWorklet.addModule('wave-paint.js');
}
  • wave-paint.js
registerPaint('wave', class {
  static get inputProperties() { return ['--wave-color', '--wave-frequency']; }
  
  paint(ctx, size, properties) {
    const color = properties.get('--wave-color').toString();
    const frequency = parseInt(properties.get('--wave-frequency').toString(), 10);
    
    ctx.fillStyle = color;
    // 绘制波浪形状
    for(let x = 0; x < size.width; x++) {
      const y = Math.sin(x * frequency) * 10 + size.height / 2;
      ctx.fillRect(x, y, 1, 1);
    }
  }
});
  • CSS使用
.separator {
  --wave-color: #007BFF;
  --wave-frequency: 0.05;
  background-image: paint(wave);
}

通过Paint API,我们可以创建高度自定义的背景图案,不需要预加载图像,也不增加额外的网络请求。

10.2.3 拓展案例 1:利用 Properties and Values API 实现主题切换

通过定义自定义CSS属性,我们可以更灵活地实现暗模式和亮模式的主题切换。

  • 注册属性
if ('registerProperty' in CSS) {
  CSS.registerProperty({
    name: '--primary-color',
    syntax: '<color>',
    inherits: true,
    initialValue: '#333',
  });
}

10.2.4 拓展案例 2:使用 Layout API 实现瀑布流布局

瀑布流布局是一种常见的网页布局方式,但CSS本身不直接支持。利用Layout API,我们可以自定义布局算法。

  • 注册布局
if ('layoutWorklet' in CSS) {
  CSS.layoutWorklet.addModule('masonry-layout.js');
}
  • masonry-layout.js
registerLayout('masonry', class {
  // 定义布局算法
});
  • CSS使用
.container {
  display: layout(masonry);
}

通过CSS Houdini,开发者可以突破传统CSS的限制,创造出独一无二的布局和效果,为用户带来前所未有的体验。Houdini开启了CSS的新时代,让样式表的魔法更加强大和灵活。随着浏览器支持度的提高,未来的Web开发将更加丰富和多彩。

在这里插入图片描述


10.3 构建更加动态和互动的用户界面

随着Web技术的进步,构建动态和互动的用户界面(UI)成为了可能。CSS提供了多种工具和技术,帮助开发者和设计师创建出既美观又富有动态效果的网页,增强用户体验。

10.3.1 基础知识

  • CSS动画:通过@keyframesanimation属性,可以为元素创建复杂的动画效果。
  • CSS过渡transition属性允许元素在不同状态之间平滑过渡,适用于简单的动效。
  • 变换(Transforms)transform属性提供了旋转、缩放、移动和倾斜等效果,为元素添加动态感。
  • 滤镜(Filters)filter属性可以为元素添加视觉效果,如模糊、亮度调整和对比度调整等。
  • 剪裁和蒙版clip-pathmask属性可以创建复杂的形状和视觉效果,用于元素的剪裁和遮罩。

10.3.2 重点案例:创建一个带有动画的加载指示器

为了提升用户等待内容加载时的体验,我们将创建一个简单而优雅的加载指示器。

  • HTML 结构
<div class="loader"></div>
  • CSS样式
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.loader {
  border: 4px solid #f3f3f3;
  border-top: 4px solid #3498db;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  animation: spin 2s linear infinite;
}

这个例子展示了如何使用CSS动画和transform属性创建一个旋转的加载指示器,增强页面的互动性和视觉吸引力。

10.3.3 拓展案例 1:使用过渡实现交互式按钮

实现一个按钮,当用户悬停或点击时,按钮有视觉反馈。

  • HTML结构
<button class="btn">悬停我</button>
  • CSS样式
.btn {
  background-color: #007bff;
  color: white;
  padding: 10px 20px;
  border: none;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.btn:hover {
  background-color: #0056b3;
}

这个例子使用了CSS过渡,为按钮添加了简单的互动效果,使其在悬停时改变背景色。

10.3.4 拓展案例 2:利用滤镜和剪裁路径创建特殊效果

假设我们想为一个促销活动的横幅添加一些特殊的视觉效果。

  • HTML结构
<div class="promo-banner"></div>
  • CSS样式
.promo-banner {
  width: 100%;
  height: 300px;
  background-image: url('promo-background.jpg');
  filter: grayscale(50%);
  clip-path: polygon(0 0, 100% 0, 100% 75%, 0 100%);
}

通过结合使用CSS滤镜和剪裁路径,我们为横幅添加了灰度滤镜和一个不规则的剪裁形状,创建出独特且吸引人的视觉效果。

通过这些案例,我们可以看到CSS提供的丰富特性如何使得构建动态和互动的用户界面成为可能。随着CSS的不断发展,我们期待未来将有更多创新的技术和方法被引入,使Web界面设计和用户体验达到新的高度。

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

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

相关文章

OpenMVG(EXIF、畸变、仿射特征、特征匹配)

本人之前也研究过OpenMVS但是对于OpenMVG只是原理层次的了解&#xff0c;因此乘着过年期间对这个库进行详细的学习。 目录 1 OpenMVG编译与简单测试 1.1 sfm_data.json获取 1.2 计算特征 2 OpenMVG整个流程的运行测试 3 OpenMVG实战 3.1 SVG绘制 3.2 解析图片的EXIF信息…

Linux:信号的保存

文章目录 信号相关概念信号递达信号未决信号阻塞内核中的示意图 信号集的操作函数 前面对于信号的产生中对操作系统有了一个基础的认知&#xff0c;对于一个真正的操作系统来说&#xff0c;进程是由操作系统进行调度的&#xff0c;那操作系统本身也是代码&#xff0c;是由谁进行…

一键打造属于自己漏扫系统

0x01 工具介绍 本系统是对Web中间件和Web框架进行自动化渗透的一个系统,根据扫描选项去自动化收集资产,然后进行POC扫描,POC扫描时会根据指纹选择POC插件去扫描,POC插件扫描用异步方式扫描.前端采用vue技术,后端采用python fastapi。 0x02 安装与使用 1、Docker部署环境 编译…

Java String源码剖析+面试题整理

由于字符串操作是计算机程序中最常见的操作之一&#xff0c;在面试中也是经常出现。本文从基本用法出发逐步深入剖析String的结构和性质&#xff0c;并结合面试题来帮助理解。 String基本用法 在Java中String的创建可以直接像基本类型一样定义&#xff0c;也可以new一个 Str…

骑砍MOD天芒传奇-天芒使用方法

骑砍1战团mod天芒传奇-使用红色天芒碎片开P51战斗机_单机游戏热门视频 (bilibili.com)https://www.bilibili.com/video/BV1nm41197iA/ 一.黄色天芒碎片 天芒盒子 野外战斗H键-召唤徐天地 二.绿色天芒碎片 天芒盒子 野外战斗H键-站在巨人肩膀上战斗 三.蓝色天芒碎片 天芒盒…

华为问界M9:全方位自动驾驶技术解决方案

华为问界M9的自动驾驶技术采用了多种方法来提高驾驶的便利性和安全性。以下是一些关键技术&#xff1a; 智能感知系统&#xff1a;问界M9配备了先进的传感器&#xff0c;包括高清摄像头、毫米波雷达、超声波雷达等&#xff0c;这些传感器可以实时监测车辆周围的环境&#xff0…

车载电子电器架构 —— 电子电气系统功能开发

车载电子电器架构 —— 电子电气系统功能开发 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自己。江湖一碗茶,喝完再挣扎,出门靠自己,四海皆…

几个好用的 iphone 手机模板贴图样机

整理了几个好用的 iphone 手机模板贴图&#xff0c;分享一下。 关注订阅号「设计师工作日常」&#xff0c;发送关键词 iphone mockup ,获取下载链接。 [1] 原文阅读 我是 Just&#xff0c;这里是「设计师工作日常」&#xff0c;求点赞求关注&#xff01;

huggingface学习|用dreambooth和lora对stable diffusion模型进行微调

目录 用dreambooth对stable-diffusion-v1-5模型进行微调&#xff08;一&#xff09;模型下载和环境配置&#xff08;二&#xff09;数据集准备&#xff08;三&#xff09;模型微调&#xff08;四&#xff09;运行微调后的模型 用lora对stable-diffusion-v1-5模型进行微调&#…

windows 下安装gin

go install 执行命令&#xff0c;执行不了的参考一下 https://blog.csdn.net/weixin_42592326/article/details/135946806 Golang 中没法下载第三方包解决办法-CSDN博客 go install github.com/gin-gonic/ginlatest 还是安装不了的话&#xff0c;用手机开热点&#xff0c;电…

在程序中使用日志功能

在应用中&#xff0c;需要记录程序运行过程中的一些关键信息以及异常输出等。这些信息用来排查程序故障或者其他用途。 日志模块可以自己实现或者是借用第三方库&#xff0c;之前写过一个类似的使用Qt的打印重定向将打印输出到文件&#xff1a;Qt将打印信息输出到文件_qt log输…

PyCharm2023.3.2配置conda环境

重点在于Path to conda这一步&#xff0c;需要找到conda.bat这个文件&#xff0c;PyCharm才能识别出现有的conda环境。

配置VMware实现从服务器到虚拟机的一键启动脚本

正文共&#xff1a;1666 字 15 图&#xff0c;预估阅读时间&#xff1a;2 分钟 首先祝大家新年快乐&#xff01;略备薄礼&#xff0c;18000个红包封面来讨个开年好彩头&#xff01; 虽然之前将服务器放到了公网&#xff08;成本增加了100块&#xff0c;内网服务器上公网解决方案…

c语言游戏实战(6):走迷宫之推箱子

前言&#xff1a; 在上一篇文章当中我介绍了一个走迷宫的写法&#xff0c;但是那个迷宫没什么可玩性和趣味性&#xff0c;所以我打算在迷宫的基础上加上一个推箱子&#xff0c;使之有更好的操作空间&#xff0c;从而增强了游戏的可玩性和趣味性。 1. 打印菜单 void menu() {…

【DDD】学习笔记-UML 与彩色建模

如果某个领域已经形成了稳定的分析模式&#xff0c;在设计该领域的分析模型时&#xff0c;这些模式就可以提供有价值的参考。可惜&#xff0c;分析模式需要有人来总结和提炼&#xff0c;最好的分析模式提炼者需要兼具领域知识和软件建模能力。很早以前&#xff0c;Martin Fowle…

nodejs切换版本

sudo n 18.17.0 sudo n然后键盘上下选择

Vue核心基础6:Vue内置指令、自定义指令、生命周期

1 Vue中的内置指令 <script>const vm new Vue({el: #root,data: {n: 1,m: 100,name: Vue,str: <h3>你好</h3>}})</script> 1.1 v-text <div v-text"name"></div>1.2 v-html <div v-html"str"></div> …

SpringCloud-高级篇(二十)

下面我们研究MQ的延迟性问题 &#xff08;1&#xff09;初始死信交换机 死信交换机作用一方面可以向Public的异常交换机一样做异常消息的兜底方案&#xff0c;另一方面&#xff0c;可以处理一些超时消息&#xff0c;功能比较丰富一点 &#xff08;2&#xff09;TTL 上面学习…

Java基础:值传递和引用传递

Java在给方法传递参数时&#xff0c;有值传递和引用传递两种方式。 基本概念 值传递&#xff1a;传递对象的一个副本&#xff0c;即使副本被改变&#xff0c;也不会影响源对象&#xff0c;因为值传递的时候&#xff0c;实际上是将实参的值复制一份给形参。 引用传递&#xf…

猫头虎分享已解决Bug || ValueError: Data cardinality is ambiguous

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …