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

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

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

相关文章

【大厂AI课学习笔记】【1.6 人工智能基础知识】(1)人工智能、机器学习、深度学习之间的关系

6.1 人工智能、机器学习与深度学习的关系 必须要掌握的内容&#xff1a; 如上图&#xff1a;人工智能>机器学习>深度学习。 机器学习是人工智能的一个分支&#xff0c;该领域的主要研究对象是人工智能&#xff0c;特别是如何在经验学习中改进具体算法的性能。 深度学习…

【leetcode】965. 单值二叉树

题目链接 965. 单值二叉树 bool isUnivalTree(struct TreeNode* root) {// if (root->left ! NULL && root->right ! NULL) {// return root->val root->left->val// && root->val root->right->val// && isUnivalTr…

网站建设详细步骤和流程是什么

我们选择了白嫖雨云的二级域名 浏览器输入https://www.rainyun.com/z22_ 创建账号然后选择一个你喜欢的子域名我建议后缀选择ates.top的 选择自定义地址&#xff0c;类型选择cname 现在要选择记录值了&#xff0c;有a&#xff0c;aa&#xff0c;txt等 根据实际情况填写。就可以…

《CSS 简易速速上手小册》第9章:CSS 最佳实践(2024 最新版)

文章目录 9.1 维护大型项目的 CSS9.1.1 基础知识9.1.2 重点案例&#xff1a;构建一个可复用的 UI 组件库9.1.3 拓展案例 1&#xff1a;优化现有项目的 CSS 结构9.1.4 拓展案例 2&#xff1a;实现主题切换功能 9.2 BEM、OOCSS 和 SMACSS 方法论9.2.1 基础知识9.2.2 重点案例&…

【pip】本地和Anaconda的pip冲突时如何指定安装位置

输入指令&#xff1a; where pip 显示如下&#xff1a; D:\LenovoSoftstore\Anaconda\Scripts\pip.exe C:\python\python3.8\Scripts\pip.exe 可以看到有两个位置的pip&#xff0c;一个Anaconda下的pip&#xff0c;一个是本地的pip。 当我们使用pip安装的时候&#xff0c;系…

day37 闭包、变量提升

目录 闭包变量提升函数提升 闭包 闭包&#xff08;closure&#xff09;是一个函数以及其捆绑的周边环境状态&#xff08;lexical environment&#xff0c;词法环境&#xff09;的引用的组合。换而言之&#xff0c;闭包让开发者可以从内部函数访问外部函数的作用域。在 JavaScr…

第67讲自定义icon实现

element-plus内置有一些常用的icon供我们使用&#xff0c;但是我们假如需要用自己的icon时候&#xff0c;我们可以搞一个icon自定义组件&#xff1b; 先把icons文件放到src下&#xff1b; 再新建一个SvgIcon组件&#xff1b; index.vue <template><svg class"…

C语言:整形存储

#include<stdio.h> int main() {char a -1;signed char b -1;unsigned char c -1;printf("a%d,b%d,c%d", a, b, c);return 0; } b与a都是有符号数结果一样。a的signed相当于省略了。 运行结果 整形提升&#xff1a;整形算术运算总是以至少以缺省整型类型的精…

Hive正则表达式

Hive版本&#xff1a;hive-3.1.2 一、Hive的正则表达式概述 正则表达式是一种用于匹配和操作文本的强大工具&#xff0c;它是由一系列字符和特殊字符组成的模式&#xff0c;用于描述要匹配的文本模式。 Hive的正则表达式灵活使用解决HQL开发过程中的很多问题&#xff0c;本篇文…

AI-数学-高中-25-三角函数一三角函数对称性

原作者视频&#xff1a;【三角函数】【考点精华】3三角函数对称性&#xff08;重要&#xff09;&#xff08;中档&#xff09;_哔哩哔哩_bilibili 1.一个对称点\直线思路&#xff1a; 2.关于两点或两直线对称&#xff1a; 3.两个对称&#xff1a;一个关于点对称、一个关于直线…

数学实验第三版(主编:李继成 赵小艳)课后练习答案(八)(3)

实验八&#xff1a;近似计算 练习三 1. 按要求完成下面的任务&#xff1a; (1)求出函数 处的泰勒展开式&#xff0c;由此计算无理数e的近似值&#xff1b; clc;clear; f(x)exp(-x^2); syms x yf(x); y1matlabFunction(taylor(y,order,20)); 1/y1(1)ans 2.718283693893450 …

智能时代:创新创业的新机遇与挑战

智能时代为创新创业提供了广阔的空间和无限的可能性。以下是一些可能适合智能时代背景的创新创业方向&#xff1a; 人工智能技术应用&#xff1a;人工智能技术是当前科技领域最热门的技术之一&#xff0c;其应用范围不断扩大。创业者可以将人工智能技术应用于各个领域&#xf…

让Python遇上Office--从编程入门到自动化办公实践

最近仔细的学习了这本《让Python遇上Office》的书&#xff0c;同时把我的学习进程与心得录制了同步视频。 到今天终于把全部90集完成&#xff0c;并且上传到下面的视频平台了&#xff0c;欢迎大家观看并指正&#xff01; 西瓜视频&#xff1a;https://www.ixigua.com/7300628…

洛谷p4391 无限传输

考察字符串周期的题 题目链接 结论 要求字串 s s s的最短循环字串长就是&#xff1a; a n s n − p m t [ n ] ansn-pmt[n] ansn−pmt[n] 证明如下&#xff1a; 这是最大的前缀和后缀 现在我们做如下操作&#xff1a; 补全字段 a a a和字段 b b b&#xff0c;按子段 a a a的…

【数据结构】二叉树的顺序结构及链式结构

目录 1.树的概念及结构 1.1树的概念 1.2树的相关概念 ​编辑 1.3树的表示 1.4树在实际中的运用&#xff08;表示文件系统的目录树结构&#xff09; 2.二叉树概念及结构 2.1二叉树的概念 2.2现实中的二叉树 ​编辑 2.3特殊的二叉树 2.4二叉树的性质 2.5二叉树的存储结…

从信息隐藏到功能隐藏

本文主要记录复旦大学张新鹏教授于2022年12月在第三届CSIG中国媒体取证与安全大会上的汇报

假期刷题打卡--Day29

1、MT1224棋盘 求一个N*N棋盘中的方块总数。 格式 输入格式&#xff1a; 输入整型N 输出格式&#xff1a; 输出整型 样例 1 输入&#xff1a; 2输出&#xff1a; 5备注 考虑到取值范围&#xff0c;可用long整型定义变量 分析过程 这个题目的意思是&#xff0c;在这…

Docker 容器网络:C++ 客户端 — 服务器应用程序。

一、说明 在下面的文章中&#xff0c; 将向您概述 docker 容器之间的通信。docker 通信的验证将通过运行 C 客户端-服务器应用程序和标准“ping”命令来执行。将构建并运行两个单独的 Docker 映像。 由于我会关注 docker 网络方面&#xff0c;因此不会提供 C 详细信息。…

【Linux】学习-进程信号

进程信号 信号入门 生活角度的信号 你在网上买了很多件商品,再等待不同商品快递的到来。但即便快递没有到来,你也知道快递来临时,你该怎么处理快递。也就是你能“识别快递”,也就是你意识里是知道如果这时候快递员送来了你的包裹,你知道该如何处理这些包裹当快递员到了你…

[C# WPF] DataGrid选中行或选中单元格的背景和字体颜色修改

问题描述 WPF中DataGrid的选中行或选中者单元格&#xff0c;在焦点失去后&#xff0c;颜色会很淡&#xff0c;很不明显&#xff0c;不容易区分。 解决方法 在失去焦点的情况下&#xff0c;如何设置行或单元格与选中的时候颜色一样&#xff1f; <DataGrid.Resources>&…