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

在这里插入图片描述

文章目录

  • 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界面设计和用户体验达到新的高度。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Day46 300最长递增子序列 674最长连续递增子序列 718最长重复子数组 1143最长公共子序列

300 最长递增子序列 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序。例如&#xff0c;[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序…

Kafka 入门笔记

课程地址 概述 定义 Kafka 是一个分布式的基于发布/订阅模式的消息队列&#xff08;MQ&#xff09; 发布/订阅&#xff1a;消息的发布者不会将消息直接发送给特定的订阅者&#xff0c;而是将发布的消息分为不同的类别&#xff0c;订阅者只接受感兴趣的消息 消息队列 消息队…

【北邮鲁鹏老师计算机视觉课程笔记】04 fitting 拟合

【北邮鲁鹏老师计算机视觉课程笔记】04 fitting 拟合 1 拟合的任务 如何从边缘找出真正的线&#xff1f; 存在问题 ①噪声 ②外点、离群点 ③缺失数据 2 最小二乘 存在的问题 3 全最小二乘 度量的是点到直线的距离而不是点在y方向到直线的距离 提示&#xff1a;点到直线的…

【北邮鲁鹏老师计算机视觉课程笔记】05 Hough 霍夫变换

【北邮鲁鹏老师计算机视觉课程笔记】05 Hough 霍夫变换 1 投票策略 考虑到外点率太高 ①让直线上的每一点投票 ②希望噪声点不要给具体的任何模型投票&#xff0c;即噪声点不会有一致性的答案 ③即使被遮挡了&#xff0c;也能把直线找出来 参数空间离散化 直线相当于就是m,b两…

vue核心技术(二)

◆ 指令补充 指令修饰符 通过 "." 指明一些指令 后缀&#xff0c;不同 后缀 封装了不同的处理操作 → 简化代码 v-bind 对于样式控制的增强 为了方便开发者进行样式控制&#xff0c; Vue 扩展了 v-bind 的语法&#xff0c;可以针对 class 类名 和 style 行内样式…

网络安全检查表

《网络攻击检查表》 1.应用安全漏洞 2.弱口令&#xff0c;默认口令 3.服务器互联网暴露 4.操作系统&#xff0c;中间件安全漏洞 5.研发服务器&#xff0c;邮件服务器等安全检查

PySpark(四)PySpark SQL、Catalyst优化器、Spark SQL的执行流程、Spark新特性

目录 PySpark SQL 基础 SparkSession对象 DataFrame入门 DataFrame构建 DataFrame代码风格 DSL SQL SparkSQL Shuffle 分区数目 DataFrame数据写出 Spark UDF Catalyst优化器 Spark SQL的执行流程 Spark新特性 自适应查询(SparkSQL) 动态合并 动态调整Join策略 …

Android---Jetpack Compose学习003

Compose 状态。本文将探索如何在使用 Jetpack Compose 时使用和考虑状态&#xff0c;为此&#xff0c;我们需要构建一个 TODO 应用&#xff0c;我们将构建一个有状态界面&#xff0c;其中会显示可修改的互动式 TODO 列表。 状态的定义。在科学技术中&#xff0c;指物质系统所处…

【XR806开发板试用】轻松连上华为云实现物联网

本文为极术社区XR806试用活动文章。 一.开始 偶然的机会在网上看到了鸿蒙开发板的试用,作为一个"老鸿蒙"岂能放弃这个机会,报名之后不出意料地得到了使用名额,在此感谢极术社区. 收到开发板之后其实还有点失望了,就那么一个小小的核心板,其他啥也没有,连一根数据线…

图灵日记--MapSet字符串常量池反射枚举Lambda表达式泛型

目录 搜索树概念实现性能分析和 java 类集的关系 搜索概念及场景模型 Map的使用Map常用方法 Set的说明常见方法说明 哈希表冲突-避免-负载因子调节冲突-解决-闭散列冲突-解决-开散列/哈希桶冲突严重时的解决办法 实现和 java 类集的关系 字符串常量池String对象创建intern方法 …

MongoDB 与 mongo-express docker 安装

MongoDB 和 mongo-express 与 MySQL 不同&#xff0c;MongoDB 为 NoSQL 数据库&#xff0c;MongoDB 中没有 table &#xff0c;schema 概念&#xff0c;取而代之的 collection&#xff0c;其中 collection 存储的为 BSON 格式&#xff0c;是一种类似于 JSON 的用于存储 k-v 键…

每日五道java面试题之java基础篇(五)

第一题. final、finally、finalize 的区别&#xff1f; final ⽤于修饰变量、⽅法和类&#xff1a;final 修饰的类不可被继承&#xff1b;修饰的⽅法不可被重写&#xff1b;修饰的变量不可变。finally 作为异常处理的⼀部分&#xff0c;它只能在 try/catch 语句中&#xff0c;…

PyTorch深度学习实战(26)——多对象实例分割

PyTorch深度学习实战&#xff08;26&#xff09;——多对象实例分割 0. 前言1. 获取并准备数据2. 使用 Detectron2 训练实例分割模型3. 对新图像进行推断小结系列链接 0. 前言 我们已经学习了多种图像分割算法&#xff0c;在本节中&#xff0c;我们将学习如何使用 Detectron2 …

Netty Review - NioEventLoopGroup源码解析

文章目录 概述类继承关系源码分析小结 概述 EventLoopGroup bossGroup new NioEventLoopGroup(1); EventLoopGroup workerGroup new NioEventLoopGroup();这段代码是在使用Netty框架时常见的用法&#xff0c;用于创建两个不同的EventLoopGroup实例&#xff0c;一个用于处理连…

【计算几何】确定两条连续线段向左转还是向右转

确定两条连续线段向左转还是向右转 目录 一、说明二、算法2.1 两点的叉积2.2 两个段的叉积 三、旋转方向判别3.1 左转3.2 右转3.3 共线判别 一、说明 如果是作图&#xff0c;或者是判别小车轨迹。为了直观地了解&#xff0c;从当前点到下一个点过程中&#xff0c;什么是左转、…

树莓派4B(Raspberry Pi 4B)使用docker搭建阿里巴巴sentinel服务

树莓派4B&#xff08;Raspberry Pi 4B&#xff09;使用docker搭建阿里巴巴sentinel服务 由于国内访问不了docker hub&#xff0c;而国内镜像仓库又没有适配树莓派ARM架构的sentinel镜像&#xff0c;所以我们只能退而求其次——自己动手构建镜像。本文基于Ubuntu&#xff0c;Jav…

springboot169基于vue的工厂车间管理系统的设计

基于VUE的工厂车间管理系统设计与实现 摘 要 社会发展日新月异&#xff0c;用计算机应用实现数据管理功能已经算是很完善的了&#xff0c;但是随着移动互联网的到来&#xff0c;处理信息不再受制于地理位置的限制&#xff0c;处理信息及时高效&#xff0c;备受人们的喜爱。本…

书生谱语-大语言模型测试demo

课程内容简介 1.作业 demo1 demo2 demo3 demo4

Makefile编译原理 make 中的路径搜索_1

一.make中的路径搜索 问题&#xff1a;在实际的工程项目中&#xff0c;所有的源文件和头文件都放在同一个文件夹中吗&#xff1f; 实验1 &#xff1a; VPATH 引子 mhrubuntu:~/work/makefile1/17$ ll total 28 drwxrwxr-x 4 mhr mhr 4096 Apr 22 00:46 ./ drwxrwxr-x 7 mhr m…

《UE5_C++多人TPS完整教程》学习笔记10 ——《P11 设置加入游戏会话(Setup for Joining Sessions)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P11 设置加入游戏会话&#xff08;Setup for Joining Sessions&#xff09;》 的学习笔记&#xff0c;该系列教学视频为 Udemy 课程 《Unreal Engine 5 C Multiplayer Shooter》 的中文字幕翻译版&#xff0c;UP主&…