首页
/ HTML标准中导航过渡期Promise解析顺序的规范调整

HTML标准中导航过渡期Promise解析顺序的规范调整

2025-05-27 06:54:11作者:邓越浪Henry

在HTML标准的最新演进过程中,发现了一个关于导航API中Promise解析顺序的重要规范细节需要修正。这个细节涉及到Web应用在页面导航过程中的两个关键Promise对象——transition(过渡期)和finished(完成期)的解析顺序问题。

当前HTML标准规范文本中定义的解析顺序是transition Promise先于finished Promise解析。然而,在实际的WPT测试用例(如ordering-and-transition/navigate-intercept.html)以及Chromium浏览器的实现中,观察到的行为却是相反的——finished Promise先于transition Promise解析。

从技术实现角度来看,这两种顺序各有其合理性。transition Promise代表导航过程中的过渡阶段,而finished Promise则表示导航最终完成。现代Web应用中,开发者可能依赖这些Promise的解析顺序来实现特定的页面过渡效果或状态管理逻辑。

经过WHATWG组织成员的评估,认为测试用例和Chromium实现采用的顺序(finished先于transition)更为合理。这种顺序更符合开发者对导航生命周期的直观理解——完成事件理应发生在过渡阶段之后。因此决定对HTML标准规范进行相应修改,使其与现有实现保持一致。

这一变更虽然看似微小,但对于依赖这些Promise顺序的Web应用可能产生重要影响。Web开发者应当注意检查现有代码中是否隐含了对这些Promise解析顺序的依赖,特别是在实现复杂的页面过渡动画或导航状态管理逻辑时。

对于浏览器实现者而言,这一调整意味着需要确保其导航API实现中finished Promise在transition Promise之前解析。WebKit团队已经表示将遵循这一修改后的规范,保持与其他浏览器引擎的行为一致性。

这种规范与实现不一致的情况在Web标准演进过程中并不罕见,通常通过各方的技术讨论和评估后,会选择最合理、对开发者最友好的方案进行统一。此次调整再次体现了Web标准制定过程中实现优先的原则,以及保持各浏览器行为一致性的重要性。

登录后查看全文
热门项目推荐

项目优选

收起
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
119
175
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
806
485
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
162
252
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
116
78
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
171
259
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
321
1.06 K
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
79
2
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
719
102
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
568
50
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.05 K
0