写点什么

Svelte 5 引入 Runes 解决反应式 Web 编程的问题

作者:Bruno Couriol

  • 2023-10-26
    北京
  • 本文字数:1760 字

    阅读完需:约 6 分钟

大小:853.08K时长:04:51
Svelte 5引入Runes解决反应式Web编程的问题

在名为“Runes简介”的博客文章中,Svelte 团队展示了在 web 应用中表述反应式依赖的新语法。这种额外的语法可以提高复杂 web 应用的可维护性,进一步推进 Svelte 的企业级就绪度。


Svelte 即将推出的 runes 能够让开发人员将反应式逻辑分解并封装为标准的 JavaScript 函数,这些函数能够在整个代码库中重复使用。


在 Svelte 3 中,反应式依赖是通过.svelte文件在组件级别描述的。组件会封装一些在组件外部不可见的反应式依赖(let var语法),或者明确声明外部的反应式依赖(export let var),客户端组件可以通过Svelte的props语法使用这些依赖。对于那些既不属于本地组件,又不方面在组件接口中公开的反应式依赖,开发人员可以导入Svelte存储


Svelte 的单文件组件强烈建议开发人员将组件的三个关注点(样式、内容和行为)放到一个文件中。当这三个关注点密切相关时(比如,一起出现、变更或消失),将它们放置在一起就是非常有意义的。因此,将组件特有的样式或行为放到组件标记定义的地方(内聚原则),会使其受益匪浅。另一方面,把松散依赖于特定组件的样式或行为放在一起可能会产生可维护性问题或缺陷(如重复/过时/已消亡/缺失的代码)。理想情况下,Svelte 存储只关注单一内聚行为。


Svelte 存储包含在一个标准 JavaScript 文件中,与 RxJS 的 observable 类似,它们至少暴露了一个.subscribe接口,调用者可以通过该接口对存储中的值做出反应。存储与应用程序的组件架构解耦之后,就可以独立演进,只需保证接口不变即可。反之,客户端的变化也不必导致存储的变化。


Svelte runes 将为 Svelte 存储提供另一种语法。Svelte 团队认为,runes 是一种更好的替代方案:


现实情况是,随着应用程序复杂性的增长,确定哪些值是反应式的,哪些值是非反应式的将会变得很棘手。[......]如果代码在.svelte文件中表现为一种方式,而在.js中又表现为另一种方式,那么代码的重构就会变得非常困难。例如,如果你需要将某些内容转化到存储中,以便于在多个地方使用它。


[......] 我们发现,当开始实现复杂的事情时,存储 API 可能会变得相当笨重。此外,团队还观察到:


[......]如果超过一定的复杂度,要理解 Svelte 选择何时更新哪些值所带来的复杂性会非常难以处理。提议的 API 依赖于新的$state$derived$effect原语:


<script>    let { width, height } = $props(); // instead of `export let`
const area = $derived(width * height);
$effect(() => { console.log(area); });</script>
复制代码


除了.svelte文件之外,这三个原语均可以在.js.ts文件中使用。让开发人员通过更加重量级的语法来明确声明反应式依赖,这样能够避免遗漏或误解这些依赖关系。它还能对编译器进行一系列优化,从而加快应用程序的运行速度。Svelte 团队认为:


Signals 能够解锁细粒度的反应性,这意味着(举例来说)在一个较大列表中,某个值的变化不需要让列表中的其他成员失效。因此,Svelte 5 的速度会超乎寻常得快。


开发人员的早期反应褒贬不一。一位持有怀疑态度的开发人员在 Reddit 上写道:


难以言表!尽管我完全明白它能解决什么问题,但是它给人的感觉并不像我之前喜欢的 Svelte。以前,Svelte 与 vanilla JS 非常接近。


constletexport这样的保留字是有意使用的。即便是像onMount这样的内容,对生命周期稍有了解的人都能轻松理解并使用。甚至在整个 Svelte 中我最喜欢的$:也会消失。我希望它能够提供可选择性,而不是成为编写 Svelte 的唯一方式。


一位 Vue 开发人员则对新语法丝毫没有感到陌生


作为在 Svelte 网站上工作过几周的 Vue 开发人员,我对 runes 感觉很熟悉,我喜欢将反应式依赖暴露出来的想法,这样就可以在 js/ts 文件中重用组件逻辑或创建存储。


另一位开发人员总结了新语法的一些重要优点,如下所示:


这确实带来了我一直翘首以盼的两项改进(类型化的 props 以及在组件之外编写反应式代码的更佳方法)。


此外,Filip Tangen还撰写了一篇关于Svelte 5的详细评论,其中考虑到了优势和不足,并提出了一种新的方言(代号为 Pelte)。


Svelte 5 仍处于早期阶段。Svelte 团队警告说:


你还不能在生产环境中使用 Svelte 5。我们目前还处于研发阶段,无法告知何时可以在应用程序中使用它。不过,开发人员可以访问一个预览网站,上面有新功能的详细说明和互动式的练习场所。


原文链接:

Rethinking 'Rethinking Reactivity' - Svelte 5 Introduces Runes

2023-10-26 10:574756

评论

发布
暂无评论
发现更多内容

考试系统高并发试卷存储设计方案

Imaginary

【存储专栏】打破K/V存储的性能瓶颈

趣链科技

区块链 存储

浏览器测试的三大挑战及解决方案【译】

FunTester

软件测试 测试 FunTester 兼容性测试 浏览器测试

千万级学生管理系统的考试试卷存储方案

Geek_db27b5

华为云开天aPaaS 上线,服务千万开发者,使能行业场景化创新

华为云开发者联盟

华为云 企业应用 开天aPaaS aPaaS 华为云生态

Java变异出现错误:No enclosing instance of type XXX is accessible

华为云开发者联盟

Java

等保是强制的吗?企业不办等保有啥处罚?

行云管家

网络安全 等保 等保2.0

如何实现一款毫秒级实时数据分析引擎

Shopee技术团队

大数据 数据分析 后端 HBase

“智感超清”之HDR技术落地实践

百度开发者中心

最佳实践 音视频

谈谈汽车芯片信息安全(上篇)

SOA开发者

架构作业 - 模块四 存储架构

Leo Zhao

架构训练营

你知道怎么离线安装全局 node 模块吗?

编程三昧

大前端 npm Node 离线包 9月日更

全网通用Python点赞器(俗称刷分机器),想知道原理吗?看完本文你自己也能写个

梦想橡皮擦

9月日更

一张图读懂Z-ONE Studio Lite

SOA开发者平台

八月热点抢先看:EasyDL图像分割数据自动贴合标注,标注效率提升30倍+

百度大脑

人工智能

软件定义汽车技术体系研究

SOA开发者

送你一个Python 数据排序的好方法

华为云开发者联盟

Python 数据分析 数据排序

华为云GaussDB(for MySQL)2.0全新升级,三大技术大揭秘

华为云开发者联盟

数据库 云原生 GaussDB GaussDB(for MySQL) 华为全联接2021

冲破“薪资”瓶颈,某厂的玩转Java面试指南,他看完涨薪10k了!

Java 程序员 架构 编程语言

Python代码阅读(第28篇):计算列表中位数

Felix

Python 编程 Code Programing 阅读代码

【墨天轮专访第五期】偶数科技常雷:创新改变世界,深耕云数据仓库

墨天轮

数据库 国产数据库

一张图读懂Z-ONE Digital Car

SOA开发者平台

金九银十已经过半还没拿到offer?阿里大牛熬夜整理的Java面试总结,网友已被震惊到说不出话!

Java 编程 面试 程序人生 金九银十

Linux用户/用户组编辑

在即

9月日更

滴滴 x StarRocks:极速多维分析创造更大的业务价值

StarRocks

数据库 数据分析 滴滴 Clickhouse StarRocks

Redis可观测最佳实践,5大关键指标最全解析!

观测云

redis

一张图读懂Z-ONE Digital Car

SOA开发者

2021字节跳动面试总监首发1121道LeetCode算法刷题笔记(含答案)

Java 面试 程序人生 计算机

多租户是什么意思?怎么理解?

行云管家

云计算 运维 SaaS

一张图读懂Z-ONE Studio Lite

SOA开发者

横空出世!复盘B站面试坑我最深的JDK源码剖析,全是干货!

Java 程序员 架构 架构师 计算机

Svelte 5引入Runes解决反应式Web编程的问题_架构/框架_InfoQ精选文章