《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.rhkb.cn/news/255665.html

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

相关文章

【JMX】JAVA监控的基石

目录 1.概述 2.MBean 2.1.Standard MBean 2.2.Dynamic MBean 2.3.Model Bean 2.4.Dynamic MBean和Model Bean的区别 2.5.MXBean 2.6.Open Bean 3.控制台 1.概述 什么是JMX&#xff0c;首先来看一段对话&#xff1a; Java Management Extensions&#xff08;JMX&#…

四.Linux实用操作 12-14.环境变量文件的上传和下载压缩和解压

目录 四.Linux实用操作 12.环境变量 环境变量 环境变量--PATH $ 符号 自行设置环境变量 自定义环境变量PATH 总结 四.Linux实用操作 13.文件的上传和下载 上传&#xff0c;下载 rz&#xff0c;sz命令 四.Linux实用操作 14.压缩和解压 压缩格式 tar命令 tar命令压缩…

Java核心设计模式:代理设计模式

一、生活中常见的代理案例 房地产中介&#xff1a;客户手里没有房源信息&#xff0c;找一个中介帮忙商品代购&#xff1a;代理者一般有好的资源渠道&#xff0c;降低购物成本&#xff08;如海外代购&#xff0c;自己不用为了买东西出国&#xff09; 二、为什么要使用代理 对…

2024最新版Sublime Text 4安装使用指南

2024最新版Sublime Text 4安装使用指南 Installation and Usage Guide to the Latest Sublime Text 4 in 2024 By JacksonML 0. Sublime Text是什么&#xff1f; Sublime Text 由自定义组件构建&#xff0c;支持Python, Java, C/C等多种编程语言&#xff0c;并为用户提供无与…

第74讲Breadcrumb 面包屑实现

Breadcrumb 面包屑实现 为了实现二级路由&#xff0c;我们搞成搞个子路由&#xff0c;对于二级菜单 const routes [{path: /,name: 首页,component: () > import(../views/layout),redirect:/home,children:[{path: /home,name: 首页,component: () > import(../views…

Redis篇之过期淘汰策略

一、数据的过期策略 1.什么是过期策略 Redis对数据设置数据的有效时间&#xff0c;数据过期以后&#xff0c;就需要将数据从内存中删除掉。可以按照不同的规则进行删除&#xff0c;这种删除规则就被称之为数据的删除策略&#xff08;数据过期策略&#xff09;。 2.过期策略-惰…

Peter算法小课堂—单调队列

祝大家新年快乐&#xff01; 今天这一次有点简单。 单调队列有两个要点&#xff0c;一个是单调&#xff0c;另一个就是我们的队列。 听到队列&#xff0c;我相信大家一定会想到它的好朋友BFS吧。但是……今天……可……没……那么……简单哦。 西佳佳偶像天团1 题目描述 …

MySQL-----DCL基础操作

▶ DCL简介 DCL英文全称是Data ControlLanguage(数据控制语言)&#xff0c;用来管理数据库用户、控制数据库的访问权限。 DCL--管理用户 ▶ 查询用户 use mysql; select * from user; ▶ 创建用户 ▶ 语法 create user 用户名主机名 identified by 密码 设置为在任意主机上访问…

第67讲自定义icon实现

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

机器人学、机器视觉与控制 上机笔记(第一版译文版 2.1章节)

机器人学、机器视觉与控制 上机笔记&#xff08;第一版译文版 2.1章节&#xff09; 1、前言2、本篇内容3、代码记录3.1、新建se23.2、生成坐标系3.3、将T1表示的变换绘制3.4、完整绘制代码3.5、获取点*在坐标系1下的表示3.6、相对坐标获取完整代码 4、结语 1、前言 工作需要&a…

Linux操作系统运维-Docker的基础知识梳理总结

Linux操作系统运维-Docker的基础知识梳理总结 docker用来解决不同开发人员软件调试时环境不统一的问题&#xff0c;保证了程序调试时运行环境的一致性。docker的设计理念便是一处镜像&#xff0c;处处运行&#xff0c;即通过产生用户软件&#xff0c;运行环境及其运行配置的统一…

ElasticSearch级查询Query DSL上

目录 ES高级查询Query DSL match_all 返回源数据_source 返回指定条数size 分页查询from&size 指定字段排序sort 术语级别查询 Term query术语查询 Terms Query多术语查询 exists query ids query range query范围查询 prefix query前缀查询 wildcard query通…

NAT——网络地址转换、NAPT

网络地址转换 NAT (Network Address Translation) 1994 年提出。 需要在专用网连接到互联网的路由器上安装 NAT 软件。 装有 NAT 软件的路由器叫做 NAT路由器&#xff0c;它至少有一个有效的外部全球 IP 地址。 所有使用本地地址的主机在和外界通信时&#xff0c;都要在 NA…

2024智慧城市新纪元:引领未来,重塑都市生活

随着科技的飞速发展和数字化转型的不断深入&#xff0c;2024年智慧城市领域迎来了全新的发展格局。 这一年&#xff0c;智慧城市的建设更加注重人性化、可持续性和创新性&#xff0c;为城市居民带来了前所未有的便捷与舒适。以下将重点关注智慧城市的几个核心内容&#xff0c;…

【Web】Spring rce CVE-2022-22965漏洞复现学习笔记

目录 原理概览 漏洞简述 Tomcat AccessLogValve 和 access_log 例题: 原理概览 spring框架在传参的时候会与对应实体类自动参数绑定&#xff0c;通过“.”还可以访问对应实体类的引用类型变量。使用getClass方法&#xff0c;通过反射机制最终获取tomcat的日志配置成员属性…

【十五】【C++】list的简单实现

list 的迭代器解引用探究 /*list的迭代器解引用探究*/ #if 1 #include <list> #include <vector> #include <iostream> #include <algorithm> using namespace std;class Date {private:int _year;int _month;int _day;public:Date(): _year(2024), _m…

继承

1.继承的作用 有些类与类之间存在特殊关系&#xff0c;下级别的成员除了拥有上一级别的共性&#xff0c;还有自己的特性。 这个时候我们就可以考虑利用继承技术&#xff0c;减少重复代码。 总结&#xff1a; 继承的好处&#xff1a;可以减少重复的代码 class A : public B;…

【深度学习】:实验6布置,图像自然语言描述生成(让计算机“看图说话”)

清华大学驭风计划 因为篇幅原因实验答案分开上传&#xff0c;深度学习专栏持续更新中&#xff0c;期待的小伙伴敬请关注 实验答案链接http://t.csdnimg.cn/bA48U 有任何疑问或者问题&#xff0c;也欢迎私信博主&#xff0c;大家可以相互讨论交流哟~~ 案例 6 &#xff1a;图像自…

VTK 三维场景的基本要素(相机) vtkCamera 相机的运动

相机的运动 当物体在处于静止位置时&#xff0c;相机可以在物体周围移动&#xff0c;摄取不同角度的图像 移动 移动分为相机的移动&#xff0c;和相机焦点的移动&#xff1b;移动改变了相机相对焦点的位置&#xff0c;离焦点更近或者更远&#xff1b;这样就会改变被渲染的物体…

阿里云游戏服务器一年费用多少?

阿里云游戏服务器租用价格表&#xff1a;4核16G服务器26元1个月、146元半年&#xff0c;游戏专业服务器8核32G配置90元一个月、271元3个月&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云游戏专用服务器详细配置和精准报价&#xff1a; 阿里云游戏服务器租用价格表 阿…