当前位置: 首页 > article >正文

Svelte 现实世界指南(四)

原文zh.annas-archive.org/md5/14dc6d5ba3099ee8ed407418d0a0711b译者飞龙协议CC BY-NC-SA 4.0第十五章使用过渡实现无障碍在过去两章中我们学习了如何在 Svelte 中使用过渡。当正确使用时过渡可以增强用户体验引导用户的注意力提供反馈并为界面增添一层光泽。然而对于患有前庭功能障碍的用户来说这些动画可能会感到不适甚至可能造成伤害。因此在创造引人入胜的动画和确保它们不会对有特定需求的用户产生负面影响之间取得平衡是至关重要的。在本章中我们将深入探讨使网络过渡对患有前庭功能障碍的用户更加无障碍的技术探索尊重用户对运动偏好的 CSS 和 JavaScript 方法。到本章结束时你将更好地理解网络无障碍以及如何创建更包容的 Web 应用程序以满足所有用户的具体需求或偏好。本章将涵盖以下内容什么是网络无障碍使用prefers-reduced-motion理解用户偏好减少 Svelte 过渡的运动为无法访问的用户提供替代过渡让我们从探讨什么是网络无障碍开始。技术要求本章中的所有代码都可以在以下链接找到github.com/PacktPublishing/Real-World-Svelte/tree/main/Chapter15/01-accessible-transition什么是网络无障碍无障碍是指产品、设备、服务或环境的设计以便尽可能多的人可以使用无论他们可能有什么物理、感官或认知障碍。确保网站对所有用户都无障碍至关重要。有许多残疾可能会影响用户在网站上的体验。确保网站的无障碍性使得所有人无论他们的能力如何都能平等地访问到其他人可用的相同服务和信息。许多可能妨碍网站用户体验的残疾中前庭功能障碍是其中之一。在本章中我们将特别关注提高患有前庭功能障碍的人士的无障碍性。前庭功能障碍是影响内耳和大脑的疾病它们可能导致平衡、空间定位和运动感知困难。想象一下你身体的自然平衡感不正常。这就像头晕或感觉不稳。你脚下的地面感觉不稳定你周围看到的东西似乎在移动即使你站着不动。对于患有前庭功能障碍的人来说某些视觉刺激如网页上移动或闪烁的内容可能会引发头晕、恶心或偏头痛等症状。我们在第十三章和第十四章中学习了如何添加过渡以使我们的应用程序对用户更具吸引力。然而对于有前庭功能障碍的用户这些过渡可能会无意中提供负面的体验。大多数操作系统提供可访问性设置使用户能够减少或删除动画。这些可访问性偏好可以被网络应用程序用来创建包容性的用户体验。因此让我们探索一个网络应用程序如何访问用户的可访问性偏好。使用prefers-reduced-motion理解用户偏好大多数操作系统都提供可访问性设置允许用户禁用动画效果。例如在 Windows 11 中您可以导航到设置|可访问性|视觉效果|动画效果取消选中动画效果选项以关闭动画。图 15.1Windows 11 中的动画效果选项在网络应用程序中您可以使用prefers-reduced-motionCSS 媒体查询来确定用户是否在他们的设备上激活了减少或消除非必要运动的设置。以下是如何使用prefers-reduced-motionCSS 媒体查询的示例media(prefers-reduced-motion:reduce){div{/* Removes animation */animation:none;}}在前面的代码片段中如果用户表示偏好减少运动我们将 CSSanimation属性设置为none以从div元素中移除动画。或者除了使用 CSS 之外您还可以使用 JavaScript 来确定用户对减少运动的偏好。window.matchMedia方法允许您检查网页是否匹配给定的媒体查询字符串。在下面的代码片段中我们使用window.matchMedia来测试prefers-reduced-motionCSS 媒体查询是否匹配constmediaQuerywindow.matchMedia((prefers-reduced-motion: reduce));constmatchesmediaQuery.matches;如果用户偏好减少运动则前面代码片段中matches的值将为true否则matches的值将为false。用户在浏览网页时可能会更改他们的可访问性偏好。为了在用户更改对减少运动的偏好时得到通知我们可以监听媒体查询的change事件。以下是方法constmediaQuerywindow.matchMedia((prefers-reduced-motion: reduce));mediaQuery.addEventListener(change,(){letmatchesmediaQuery.matches;});在前面的代码片段中每当用户更改他们对减少运动的偏好时传递给change事件处理器的监听函数将被调用。它将通过mediaQuery.matches评估更新的用户偏好。既然我们已经学会了如何通过prefers-reduced-motion确定用户对减少运动的偏好让我们看看我们如何可以使用它来减少有前庭功能障碍用户的 Svelte 过渡。减少 Svelte 过渡中的运动在学习了如何获取用户对减少运动的偏好之后现在让我们通过减少过渡中的不必要的动作来尊重这一偏好这可能会引发前庭不适。在下面的代码块中有一个我们 Svelte 组件的示例该组件将fly过渡应用于列表项scriptimport{fly}fromsvelte/transition;exportletlist[];/scriptul{#each listasitem}li transition:fly{{x:40}}{item}/li{/each}/ul在前面的代码中每当向列表中添加新项目时一个新的li元素将从右侧飞入并插入到列表中。这种飞行运动可能成为前庭功能障碍用户的触发因素。然而飞行过渡并非必需因为即使没有它应用程序仍然可以正常工作。因此如果用户在系统设置中表明了偏好减少运动我们应该通过减少或移除飞行过渡来尊重这一偏好。实现这一点的办法是将fly过渡的持续时间设置为0。这样过渡将不会花费任何时间来播放和完成实际上将不会播放。这是之前 Svelte 组件的修改版本如果用户偏好减少运动则不会播放fly过渡scriptimport{fly}fromsvelte/transition;exportletlist[];constmediaQuerywindow.matchMedia((prefers-reduced-motion: reduce));letprefersReducedMotionmediaQuery.matches;mediaQuery.addEventListener(change,(){prefersReducedMotionmediaQuery.matches;});/scriptul{#each listasitem}li transition:fly{{x:40,duration:prefersReducedMotion?0:400,}}{item}/li{/each}/ul在前面的代码片段中我们通过检查 CSS 媒体查询prefers-reduced-motion: reduce是否匹配来确定用户是否偏好减少运动并将此信息存储在名为prefersReducedMotion的变量中。如果prefersReducedMotion为true表示用户偏好减少运动则我们将fly过渡的持续时间设置为0。当向列表中添加新项目时用户将看不到任何飞行运动。另一方面如果用户没有前庭功能障碍并且没有表达对减少运动效果的偏好那么prefersReducedMotion将为false。在这种情况下fly过渡的持续时间将被设置为400 ms并且每当向列表中添加新项目时都会显示飞行过渡。然而并非所有过渡都会触发前庭运动障碍。例如fade过渡作为一种更微妙的动画对前庭功能障碍用户的影响较小。我们不必通过将它们的持续时间设置为0来完全消除过渡而是可以选择用更温和的过渡来替换更强烈的过渡。我们将在下一节中深入探讨这种方法。为无法访问的用户提供替代过渡前庭功能障碍用户在接触到基于运动的动画如缩放或平移大对象时可能会感到不适。然而他们通常受更微妙的动画如淡入的影响较小。将所有过渡设置为淡入效果以适应前庭功能障碍用户并非万能的解决方案。最好总是寻求用户自身的反馈。我们将继续使用上一节中的相同示例并探讨当用户偏好减少运动时如何从fly过渡切换到fade过渡。需要注意的一点是在 Svelte 中不允许对一个元素应用超过一个过渡。例如以下代码是无效的会导致构建错误div transition:fade transition:fly/这意味着我们不能将两个过渡应用于一个元素然后决定使用哪一个。我们必须找到一种方法在只对一个元素应用一个过渡的同时在不同的过渡之间切换。正如我们在第十四章中学习到的创建自定义过渡Svelte 中的过渡是一个遵循过渡契约的函数。函数的返回值决定了过渡将如何执行。因此实现一个根据条件在两个过渡之间切换的过渡的一种方法是创建一个自定义过渡该过渡根据条件返回不同的过渡配置。我们的自定义过渡可能看起来像以下代码根据用户是否偏好减少运动返回不同的过渡配置scriptfunctionaccessibleFly(node,params){constmediaQuerywindow.matchMedia((prefers-reduced-motion: reduce));constmatchesmediaQuery.matches;if(matches){// user prefers reduced motion// return a fade transition}else{// return a fly transition}}/scriptul{#each listasitem}li transition:accessibleFly{{x:40}}{item}/li{/each}/ul在前面的代码片段中我们定义了一个accessibleFly过渡这是一个更易于访问的fly过渡如果用户偏好减少运动它将切换到fade过渡。现在我们需要确定在我们的自定义accessibleFly过渡中的每个条件情况下应该返回什么。重要的是要记住在 Svelte 中过渡是一个 JavaScript 函数。因此我们可以将fly和fade过渡都作为函数来调用并且返回值将是每个相应过渡的过渡配置。通过这样做我们可以从我们的accessibleFly过渡中返回这些值从而有效地使我们的过渡可以是fly或fade过渡具体取决于用户的偏好。下面是更新后的accessibleFly过渡scriptfunctionaccessibleFly(node,params){constmediaQuerywindow.matchMedia((prefers-reduced-motion: reduce));constmatchesmediaQuery.matches;if(matches){// user prefers reduced motionreturnfade(node,params);}else{returnfly(node,params);}}/script在前面的代码片段中我们根据用户的偏好从fade或fly过渡中返回值。我们将传递给我们的accessibleFly过渡的node和params值传递给fade和fly过渡。node和params值指定了过渡应用于哪个元素并提供了用户参数例如duration和delay。这些对于fade和fly过渡来说很有用可以确定过渡应该如何执行。通过前面的代码更改我们现在有一个名为accessibleFly的可访问fly过渡默认情况下它将使元素在过渡过程中飞出。然而如果用户表示偏好减少运动accessibleFly过渡将使元素淡出。由此我们得到了一个既吸引大多数用户又考虑那些偏好减少运动的人的过渡。您可以在github.com/PacktPublishing/Real-World-Svelte/tree/main/Chapter15/01-accessible-transition找到accessibleFly过渡的代码。摘要在本章中我们探讨了无障碍访问在网页设计中的重要性以及如何实现考虑前庭功能障碍用户偏好的过渡效果。通过了解基于运动的动画对前庭功能障碍用户的影响我们可以创建更包容和用户友好的网络应用程序。我们学习了关于prefers-reduced-motion媒体查询的知识它允许我们检测用户是否在其系统设置中表明了对减少运动的需求。使用这个媒体查询我们可以调整我们的过渡效果以减少运动量或者完全移除对偏好减少运动的用户。我们还讨论了如何在 Svelte 中创建自定义过渡以实现无障碍访问。我们查看了一个名为accessibleFly的自定义过渡示例它根据用户的减少运动偏好在fly和fade过渡之间切换。这个自定义过渡考虑到了患有前庭功能障碍的用户同时为其他用户提供吸引人和有趣的过渡效果。总结来说无障碍访问在网页设计中至关重要过渡效果也不例外。通过考虑所有用户的偏好和需求包括前庭功能障碍用户我们可以创建更包容和用户友好的网络应用程序。

相关文章:

Svelte 现实世界指南(四)

原文:zh.annas-archive.org/md5/14dc6d5ba3099ee8ed407418d0a0711b 译者:飞龙 协议:CC BY-NC-SA 4.0 第十五章:使用过渡实现无障碍 在过去两章中,我们学习了如何在 Svelte 中使用过渡。当正确使用时,过渡可…...

Mavlink协议解析:从Pixhawk飞控到QGC地面站的完整通信流程

Mavlink协议深度解析:构建Pixhawk与QGC的高效通信桥梁 当Pixhawk飞控的LED指示灯开始规律闪烁,QGC地面站的地图上突然出现了一个蓝色圆点——这看似简单的连接背后,隐藏着一套精密的通信语言体系。Mavlink协议就像无人机系统的神经网络&#…...

告别穿模与漂移!南洋理工团队提出HMR新框架:用视觉大模型对齐人体姿态

点击下方卡片,关注「3D视觉工坊」公众号选择星标,干货第一时间送达本文一作投稿发布 | 来源:3D视觉工坊「3D视觉从入门到精通」知识星球(点开有惊喜) !星球内有20多门3D视觉系统课程、300场顶会讲解、顶会论文最新解读、海量3D视觉…...

CPAL脚本自动化测试 ———— 深度解析Test Report系列函数与应用场景

1. 为什么我们需要定制化测试报告? 在车载网络测试领域,特别是涉及自动驾驶功能的验证时,一个标准的测试报告往往无法满足工程师的需求。想象一下,当你花了三天三夜跑完2000个测试用例后,拿到的报告却只有简单的"…...

OpenClaw与千问3.5-35B-A3B-FP8低成本方案:自建模型接口替代OpenAI高价调用

OpenClaw与千问3.5-35B-A3B-FP8低成本方案:自建模型接口替代OpenAI高价调用 1. 为什么需要替代OpenAI高价调用 去年冬天的一个深夜,我盯着OpenAI API账单上那个刺眼的数字——$127.83,这只是一个月的测试费用。当时我正在用OpenClaw做一个自…...

提升效率:用快马一键生成模块化openclaw控制代码库

最近在做一个机器人项目,需要控制openclaw机械爪完成各种抓取任务。刚开始自己从头写控制代码时,发现光是启动流程就要处理一堆底层细节,比如初始化通信、校准位置、设置默认参数等等,不仅重复劳动,还容易出错。后来尝…...

STM32标准库开发入门与实战指南

1. STM32入门指南:从零开始掌握标准库开发作为一名嵌入式开发者,我深知STM32的学习曲线有多陡峭。记得我第一次接触STM32时,面对密密麻麻的寄存器手册和复杂的开发环境,完全不知从何入手。经过多年的项目实践和教学经验&#xff0…...

OpenClaw跨平台控制:Qwen3.5-9B管理多台电脑

OpenClaw跨平台控制:Qwen3.5-9B管理多台电脑 1. 为什么需要跨设备自动化管理 去年夏天,我同时处理三个项目时遇到了一个典型问题:每天需要在三台不同电脑上重复执行数据同步、日志收集和报告生成。手动操作不仅耗时,还经常遗漏步…...

Vivado Linux版安装空间不足?手把手教你如何优化磁盘空间分配

Vivado Linux版安装空间优化实战指南:从130G到80G的瘦身方案 当你在Linux系统上第一次看到Vivado安装程序提示需要130GB以上的磁盘空间时,那种震惊感我至今记忆犹新。作为一名长期在ThinkPad X1 Carbon上工作的FPGA开发者,我深刻理解空间受限…...

STM32精准延时实现与Keil调试技巧

1. 精准延时在单片机开发中的重要性在STM32等嵌入式系统开发中,精准延时是基础但至关重要的功能。我最近调试一块自制的STM32开发板时,就遇到了需要精确控制时序的场景。比如在驱动LCD屏幕时,某些控制信号需要维持15ms的精确延时,…...

Winbond W25N/W25M系列SPI NAND Flash驱动开发指南

1. Winbond W25N系列SPI NAND Flash驱动库技术解析Winbond W25N系列(含W25N01GV、W25N02GV等)与W25M系列(如W25M02GW双芯片封装)是工业级高可靠性SPI NAND Flash存储器,广泛应用于嵌入式系统中替代传统并行NAND或eMMC方…...

DLSS Swapper:3步解锁游戏性能倍增的AI优化工具

DLSS Swapper:3步解锁游戏性能倍增的AI优化工具 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper DLSS Swapper是一款专为PC游戏玩家设计的深度学习超级采样(DLSS)版本管理工具,通过智能环境诊断、…...

AI绘画工作流:OpenClaw调度千问3.5-35B-A3B-FP8生成SD提示词

AI绘画工作流:OpenClaw调度千问3.5-35B-A3B-FP8生成SD提示词 1. 为什么需要自动化提示词生成 在Stable Diffusion创作中,最耗时的环节往往不是渲染过程,而是反复调试提示词(prompt)。我曾在一次商业插画项目中&#…...

抖音视频批量下载终极指南:5分钟掌握免费去水印技巧

抖音视频批量下载终极指南:5分钟掌握免费去水印技巧 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support…...

OpenClaw截图分析进阶:千问3.5-9B识别UI元素与操作建议

OpenClaw截图分析进阶:千问3.5-9B识别UI元素与操作建议 1. 为什么需要截图分析能力? 上周我在测试一个内部工具时遇到了一个典型问题——某个按钮在特定分辨率下会消失不见。手动排查需要反复调整窗口尺寸并肉眼检查,效率极低。这时我想到了…...

嵌入式轻量级数值优化库:面向MCU的确定性参数寻优方案

1. 项目概述Optimization 是一个面向嵌入式平台的轻量级数值优化库,专为 Arduino 及兼容 MCU(如 STM32、ESP32、nRF52 等)设计,其核心目标是在资源受限环境下,对用户定义的单目标标量函数 f(x₁, x₂, ..., xₙ) 进行参…...

OpenClaw自动化测试:Kimi-VL-A3B-Thinking多模态交互验证框架

OpenClaw自动化测试:Kimi-VL-A3B-Thinking多模态交互验证框架 1. 为什么需要AI驱动的自动化测试 去年接手一个客户端项目时,我遇到了一个典型痛点——每次发版前的手动回归测试需要3个人天。更麻烦的是,UI微调导致的视觉差异很难通过传统断…...

嵌入式系统XIP技术:原理、实现与优化

1. XIP技术核心概念解析eXecute In Place(XIP)技术是现代嵌入式系统中的一项关键创新。简单来说,它允许CPU直接从非易失性存储器(如NOR Flash)中读取并执行代码,而无需先将代码复制到RAM中。这种技术最早应…...

GetQzonehistory:终极QQ空间回忆一键保存指南

GetQzonehistory:终极QQ空间回忆一键保存指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还在担心QQ空间里那些珍贵的青春记忆会随着时间消失吗?GetQzonehis…...

边缘检测算法选型指南:从Sobel到Canny的5个实际场景对比(含医疗/自动驾驶案例)

边缘检测算法实战选型:医疗影像与自动驾驶场景下的Sobel与Canny深度评测 在计算机视觉领域,边缘检测作为图像处理的基础环节,直接影响着后续特征提取和目标识别的准确性。面对医疗影像分析、自动驾驶感知等对精度和实时性要求极高的场景&…...

Figma Make 提示词工程化:构建从布局、组件、交互到风格的稳定设计系统

1. 从零散到系统:为什么需要工程化提示词 刚开始用Figma Make做设计时,我和大多数人一样,每次生成页面都要重新写一遍提示词。最头疼的是明明想要类似的风格,结果生成的页面总是"飘忽不定"——今天按钮圆角是8px&#x…...

Python数据分析实战:用Seaborn绘制炫酷相关性热力图(附完整代码)

Python数据分析实战:用Seaborn绘制炫酷相关性热力图 数据分析工作中,相关性分析是理解变量间关系的核心技能。而热力图作为直观展示相关性的工具,已经成为数据科学家和商业分析师的标准配置。本文将带你从零开始,掌握用Seaborn绘…...

DICOM序列实时渲染从28fps到126fps:C++无锁队列+GPU命令缓冲复用+ROI局部重绘的工业级调优日志

第一章:DICOM序列实时渲染性能跃迁全景概览 现代医学影像工作流对DICOM序列的实时可视化提出严苛要求:从百层CT扫描到高分辨率MRI动态序列,传统CPU软渲染方案常遭遇帧率跌破15 FPS、交互延迟超300ms的瓶颈。近年来,GPU加速管线、零…...

OpenClaw安全防护指南:Qwen3.5-9B-AWQ-4bit执行权限管控

OpenClaw安全防护指南:Qwen3.5-9B-AWQ-4bit执行权限管控 1. 为什么需要安全防护? 当我第一次在本地部署OpenClaw对接Qwen3.5-9B-AWQ-4bit模型时,最让我后怕的是发现它竟然能直接删除我的工作目录。这个开源智能体框架赋予了AI像人类一样操作…...

Windows 11上保姆级教程:用Ollama本地部署DeepSeek-R1 8B,再也不用担心API费用和网络延迟了

Windows 11本地AI部署实战:OllamaDeepSeek-R1 8B全流程指南 在AI技术快速发展的今天,越来越多的开发者和中小企业开始关注如何在本地环境中部署和运行大型语言模型。对于预算有限但对数据隐私有高要求的团队来说,本地部署不仅能显著降低成本&…...

仅限首批内测开发者获取:CPython无GIL预编译二进制+无锁标准库API速查表(含ABI兼容性矩阵与降级熔断方案)

第一章:Python无锁GIL环境下的并发模型概览Python 的全局解释器锁(GIL)长期被视为多线程 CPU 密集型任务的瓶颈。然而,随着 CPython 3.13 的正式引入“实验性无锁 GIL”(--without-pymalloc 配合 --with-gildisabled 构…...

OpenClaw多终端同步:手机遥控Phi-3-mini-128k-instruct执行电脑任务

OpenClaw多终端同步:手机遥控Phi-3-mini-128k-instruct执行电脑任务 1. 为什么需要手机遥控电脑? 上周五晚上十点半,我正躺在沙发上刷手机,突然想起有个重要文档忘在办公室电脑里了。如果按传统方式,我需要&#xff…...

C++27执行策略演进全图谱(从C++17到C++27 TS23742的5次关键修订与ABI兼容性断崖预警)

第一章:C27执行策略的范式跃迁与标准定位C27正将执行策略(Execution Policies)从“并行化提示”升格为“可验证执行契约”,标志着标准库算法语义模型的根本性重构。这一转变不再仅依赖实现对std::execution::par_unseq等策略的启发…...

家庭知识库中心:OpenClaw+Qwen3.5-9B管理个人数字资产

家庭知识库中心:OpenClawQwen3.5-9B管理个人数字资产 1. 为什么需要家庭知识库 去年搬家时,我在整理纸质文件的过程中发现一个严重问题:孩子的疫苗接种记录、房产合同、医疗报告等重要文档分散在多个文件夹中,紧急情况下根本找不…...

成本控制实战:OpenClaw+Qwen3.5-9B的Token消耗优化指南

成本控制实战:OpenClawQwen3.5-9B的Token消耗优化指南 1. 为什么需要关注Token消耗? 第一次用OpenClaw执行整夜自动化任务时,早上看到账单差点从椅子上跳起来——单次任务消耗了接近18万Token。这让我意识到,如果不加控制&#…...