2024前端框架年度总结报告(二):新生qwik+solid和次新生svelte+Astro对比 -各自盯着前端的哪些个痛点 - 前端的区域发展差异

news2024/12/27 7:55:49

引言

2024年,前端开发依然是技术领域的热点之一。随着 Web 应用的日益复杂,前端框架的更新换代也加速了。尽管 React、Vue 和 Angular 老牌框架年度总结 等“老牌”框架仍然占据着主流市场,但一些新兴的框架在不断挑战这些“巨头”的地位,它们带来了更加高效、灵活的开发体验,特别是在性能优化、开发效率和用户体验方面。

本篇文章将对 2024 年新生和次新生的前端框架进行详细对比,分析这些框架如何针对前端开发中的常见痛点提供创新解决方案。

新生框架:Qwik 和 Solid.js

1. Qwik:专注性能的“零 JavaScript”框架

star 20.9k 最新版本2.0-alpha

Qwik 是一个刚刚崭露头角的前端框架,特别适合用于构建超高性能的 Web 应用。它的核心卖点是 零 JavaScript 初始加载,这使得用户在首次访问时几乎不需要等待 JavaScript 加载,页面可以在浏览器中直接渲染。

痛点解决:

  • 首次加载慢:传统框架通常会在页面加载时执行大量的 JavaScript 来初始化组件。Qwik 通过 懒激活(Lazy Hydration)技术,只有在用户与页面交互时才会加载相应的 JavaScript,显著提升首次加载速度。
  • 大规模应用的性能瓶颈:Qwik 使用 细粒度懒加载 来加载 JavaScript,仅在必要时加载相关代码块,避免了传统框架的庞大 JavaScript 文件。

适用场景:

  • Qwik 特别适合用于构建 内容密集型、交互性较少的静态页面,例如博客、产品展示页面等。
  • 对于需要高 SEO 性能快速响应时间 的应用,Qwik 是一个理想的选择。

Qwik 示例:

import { component$, useStore } from '@builder.io/qwik';

export const Counter = component$(() => {
  const state = useStore({ count: 0 });

  return (
    <div>
      <p>计数器: {state.count}</p>
      <button onClick$={() => state.count++}>增加</button>
    </div>
  );
});

Qwik 采用 懒激活,只有在用户点击按钮时才加载 onClick$ 相关的 JavaScript 代码。

官网加载数据(shift+F5强刷新):
298 次请求
已传输163 kB
1.4 MB 条资源
完成:1.5 分钟
DOMContentLoaded:569 毫秒
加载:754 毫秒

初始化加载速度在569ms内完成


2. Solid.js:纯渲染效率的极致追求

star 32.9k 最新版本 1.9

Solid.js 是一个比 Qwik 稍微成熟的框架,尽管它依然被视为“次新生”,但它的设计理念和性能表现无疑令人震撼。Solid.js 聚焦于 声明式 UI最小化渲染开销,采用了类似 React 的组件化开发模式,但在内部使用了更为精细的 编译时优化

痛点解决:

  • 虚拟 DOM 的性能瓶颈:React 和 Vue 等框架通常依赖虚拟 DOM 来优化更新性能,但这也会引入一些额外的性能开销。Solid.js 去除了虚拟 DOM,通过直接操作 DOM 节点来实现 高效的渲染,使得它的更新速度比 React 更快。
  • 更新渲染的同步性:Solid.js 采用了更加高效的响应式编程模型,能够使数据更新与 UI 渲染更加 紧密同步,避免了传统框架中 渲染不一致 的问题。

适用场景:

  • Solid.js 非常适合用于 需要高度响应式和复杂交互的应用,如动态数据展示的仪表盘、实时消息推送、游戏等。

Solid.js 示例:

import { createSignal } from 'solid-js';

const Counter = () => {
  const [count, setCount] = createSignal(0);

  return (
    <div>
      <p>计数器: {count()}</p>
      <button onClick={() => setCount(count() + 1)}>增加</button>
    </div>
  );
};

export default Counter;

Solid.js 采用 响应式编程,通过 createSignal 实现状态管理和组件更新,直接操作 DOM 来避免虚拟 DOM 的开销。

官网强刷新数据:
32 次请求
已传输459 kB
1.3 MB 条资源
完成:12.45 秒
DOMContentLoaded:1.18 秒
加载:1.21 秒

可以明显看到首次加载和显示的时间慢一点,其实网络情况差不多,但是qwik的懒加载更多

3 热度对比

谷歌趋势,qwik
在这里插入图片描述
区域热度- 中俄solid关注高于qwik
在这里插入图片描述

总的来说,solidjs的关注度是高于qwik,尤其国内,大概率是应用场景的差异
solid.js相对来说比较稳定,但qwik商业化支持比较好,后者ssr和性能表现优秀

次新生框架:Svelte 和 Astro

1. Svelte:编译型框架的创新

虽然 Svelte 并不算是 2024 年发布的新框架,但它的影响力不断扩大。与 React、Vue 等框架不同,Svelte 采用 编译时框架 的设计,即在编译阶段将组件转换成原生的 JavaScript 代码,减少了运行时的开销。

痛点解决:

  • 运行时性能差:传统框架需要在浏览器中执行 JavaScript 代码,导致页面加载和渲染性能受限。Svelte 将这些工作提前到编译阶段,使得生成的代码运行时非常轻量和高效。
  • 复杂的状态管理:Svelte 通过 声明式的反应性(reactivity)机制,使得状态管理非常简洁而直观,减少了不必要的 useStateuseEffect 等复杂操作。

适用场景:

  • Svelte 非常适合用于 小型和中型项目,尤其是那些 不需要大型生态系统 支持的应用。对于需要高度响应性、简洁 API 的应用,Svelte 是一个非常不错的选择。

Svelte 示例:

<script>
  let count = 0;
</script>

<p>计数器: {count}</p>
<button on:click={() => count++}>增加</button>

Svelte 的核心特点是它将 所有状态管理和更新逻辑 通过编译器处理,生成的 JavaScript 代码非常简洁且高效。


2. Astro:静态站点生成的未来

Astro 是一个相对较新的框架,专注于 构建静态网站。Astro 的最大亮点在于它可以与多种前端框架(如 React、Vue、Svelte)结合使用,但它的默认行为是 无 JavaScript 的页面,只有在需要时才加载 JavaScript,最大化提升性能。

痛点解决:

  • 冗余的 JavaScript:Astro 可以与多种前端框架搭配使用,但 只在需要时加载 JavaScript,避免了传统 SPA 中一次性加载大量 JS 文件的情况,从而实现了 快速加载和极致性能
  • 静态站点的灵活性:Astro 提供了简单的 API 来生成静态内容,同时支持动态功能,这使得它成为构建 内容密集型网站(如博客、电商网站)的理想框架。

适用场景:

  • Astro 是 构建静态内容丰富的站点(如个人博客、产品展示页、营销网站)的理想选择,同时也支持与 React、Vue 等现代框架的无缝集成。

Astro 示例:

---
import Counter from './components/Counter.astro';
---

<html>
  <body>
    <h1>欢迎来到我的网站</h1>
    <Counter />
  </body>
</html>

Astro 允许你在一个页面中使用 不同的框架组件,比如 React、Vue、Svelte 等,而这些框架的 JavaScript 只有在必要时才会加载,最大限度地优化了性能。


总结:如何选择适合的框架?

在 2024 年,前端框架的创新使得开发者有了更多选择。然而,这些框架针对的痛点各不相同,选择框架时要考虑以下几点:

  • 性能优先:如果你的应用需要极致的性能,Qwik 和 Solid.js 都是值得考虑的选择。Qwik 的零 JavaScript 初始加载和 Solid.js 的虚拟 DOM 替代方案都能有效提升应用的响应速度。
  • 开发效率:如果你更看重开发效率,Svelte 和 Astro 可能会更合适。Svelte 的编译时优化和 Astro 的静态网站生成能力都能减少开发时的复杂度和维护成本。
  • 静态站点:如果你主要构建静态站点,Astro 可能是你的最佳选择,它支持多种框架并且能够轻松生成无 JavaScript 的快速

我打算出一点qwik的实践文章,并做点benchmark的东西,自己的主站也打算基于此,同时打算做的lowcode框架也用qwik+webcomponent做吧

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

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

相关文章

MBox20边缘计算网关:氢能车间数据采集的智慧引擎

氢能作为未来能源体系的重要组成部分&#xff0c;其安全、高效、环保的特性备受瞩目。在氢能车间的日常运营中&#xff0c;数据采集是确保生产流程优化、设备稳定运行及能效提升的关键环节。然而&#xff0c;面对氢能车间复杂多变的生产环境和海量数据&#xff0c;如何实现高效…

【Linux篇】权限管理 - 用户与组权限详解

一. 什么是权限&#xff1f; 首先权限是限制人的。人 真实的人 身份角色 权限 角色 事物属性 二. 认识人–用户 Linux下的用户分为超级用户和普通用户 root :超级管理员&#xff0c;几乎不受权限的约束普通用户 :受权限的约束超级用户的命令提示符是#&#xff0c;普通用…

GPS模块/SATES-ST91Z8LR:电路搭建;直接用电脑的USB转串口进行通讯;模组上报定位数据转换地图识别的坐标手动查询地图位置

从事嵌入式单片机的工作算是符合我个人兴趣爱好的,当面对一个新的芯片我即想把芯片尽快搞懂完成项目赚钱,也想着能够把自己遇到的坑和注意事项记录下来,即方便自己后面查阅也可以分享给大家,这是一种冲动,但是这个或许并不是原厂希望的,尽管这样有可能会牺牲一些时间也有哪天原…

EasyNVR中HTTP-FLV协议无法播放怎么解决?

在科技日新月异的今天&#xff0c;摄像头作为公共安全领域的重要一环&#xff0c;其技术的不断提升正显著地改变着社会的安全格局。从最初的简单监控到如今的高清智能分析&#xff0c;我们可以对特定区域进行实时监控和记录&#xff0c;为社会的安全稳定提供了强有力的保障。 问…

linux环境GitLab服务部署安装及使用

一、GitLab介绍 GitLab是利用Ruby onRails一个开源的版本管理系统&#xff0c;实现一个自托管的Git项目仓库&#xff0c;可通过Web界面进行访问公开的或者私人项目。 二、GitLab安装 1、先安装相关依赖 yum -y install policycoreutils openssh-server openssh-clients postf…

视频码率到底是什么?详细说明

视频码率&#xff08;Video Bitrate&#xff09;是指在单位时间内&#xff08;通常是每秒&#xff09;传输或处理的视频数据量&#xff0c;用比特&#xff08;bit&#xff09;表示。它通常用来衡量视频文件的压缩程度和质量&#xff0c;码率越高&#xff0c;视频质量越好&#…

DICOM MPPS详细介绍

文章目录 前言一、常规检查业务流程二、MPPS的作用三、MPPS的原理1、MPPS与MWL2、MPPS服务过程 四、MPPS的实现步骤1、创建实例2、传递状态 五、总结 前言 医院中现有的DICOM MWL(Modality Worklist)已开始逐渐得到应用&#xff0c;借助它可以实现病人信息的自动录入&#xff0…

如何手搓一个智能激光逗猫棒

背景 最近家里的猫胖了&#xff0c;所以我就想做个逗猫棒。找了一圈市场上的智能逗猫棒&#xff0c;运行轨迹比较单一&#xff0c;互动性不足。 轨迹单一&#xff0c;活动范围有限 而我希望后续可以结合人工智能物联网&#xff0c;通过摄像头来捕捉猫的位置&#xff0c;让小…

「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用

本篇将带你实现一个数字键盘应用&#xff0c;支持用户通过点击数字键输入数字并实时更新显示内容。我们将展示如何使用按钮组件和状态管理来实现一个简洁且实用的数字键盘。 关键词 UI互动应用数字键盘按钮组件状态管理用户交互 一、功能说明 数字键盘应用将实现以下功能&…

泷羽sec-shell脚本(全) 学习笔记

声明&#xff01; 学习视频来自B站up主 **泷羽sec** 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷羽sec团队无关&a…

Unity 利用Button 组件辅助Scroll View 滚动

实现 创建枚举类ScrollDir 以区分滚动方向。每组两个按钮负责同方向上左右/上下滚动。 Update 中实时获取Scroll View 滚动条当前位置。 if (dir.Equals(ScrollDir.vertical)) {posCurrent scroll.verticalNormalizedPosition; } else if (dir.Equals(ScrollDir.horizontal)…

微服务搭建----springboot接入Nacos2.x

springboot接入Nacos2.x nacos之前用的版本是1.0的&#xff0c;现在重新搭建一个2.0版本的&#xff0c;学如逆水行舟&#xff0c;不进则退&#xff0c;废话不多说&#xff0c;开搞 1、 nacos2.x搭建 1&#xff0c;首先第一步查询下项目之间的版本对照&#xff0c;不然后期会…

小程序 - 计算器

小程序交互练习 - 计算器小程序 目录 计算器 功能描述 准备工作 创建项目 配置导航栏 创建utils目录 math.js文件内容 calc.js文件内容 页面内容 页面样式内容 页面脚本事件 功能截图 总结 计算器 在日常生活中&#xff0c;计算器是人们广泛使用的工具&#xff0…

在wsl2中安装archlinux

在之前的博客中&#xff0c;我介绍了如何在虚拟机或者真实机上安装archlinux并且进行一定的配置&#xff0c;但是实际上Linux不管怎么配置在日常使用中都没有Windows简单便利&#xff0c;在开发有关Linux的程序时过去用虚拟机或者直接在Windows上使用ssh在远程服务器上进行开发…

Python毕业设计选题:基于大数据的淘宝电子产品数据分析的设计与实现-django+spark+spider

开发语言&#xff1a;Python框架&#xff1a;djangoPython版本&#xff1a;python3.7.7数据库&#xff1a;mysql 5.7数据库工具&#xff1a;Navicat11开发软件&#xff1a;PyCharm 系统展示 管理员登录 管理员功能界面 电子产品管理 系统管理 数据可视化分析看板展示 摘要 本…

点动和自锁混合控制

中继&#xff1a;KA 线圈有电&#xff0c;常开吸合&#xff0c;常闭断开 SB1——>电机转&#xff08;自锁&#xff09;——>KA1&#xff08;自锁标志位&#xff09; SB2——>电机停 SB3——>电机点动——>KA2&#xff08;点动标志位&#xff09; 严禁出现双…

Linux权限机制深度解读:系统安全的第一道防线

文章目录 前言‼️一、Linux权限的概念‼️二、Linux权限管理❕2.1 文件访问者的分类&#xff08;人&#xff09;❕2.2 文件类型和访问权限&#xff08;事物属性&#xff09;✔️1. 文件类型✔️2. 基本权限✔️3. 权限值的表示方法 ❕2.3 文件访问权限的相关设置方法✔️1. ch…

代码随想录算法训练营第51期第8天 | 344. 反转字符串、541.反转字符串 II、卡码网:54.替换数字

344. 反转字符串 344. 反转字符串https://leetcode.cn/problems/reverse-string/1.这道题很简单&#xff0c;直接使用双指针就可以 2.这里有一个可以优化的点&#xff0c;left和right-- 可以放在字符串替换的时候完成&#xff0c;没必要单独写 void reverseString(char* s, …

Linux CentOS

​阿里云开源镜像下载链接 https://mirrors.aliyun.com/centos/7/isos/x86_64/ VMware 安装 CentOS7 自定义 下一步 选择稍后安装操作系统 选择 输入 查看物理机CPU内核数量 CtrlShiftEsc 总数不超过物理机内核数量 推荐内存 自选 推荐 推荐 默认 拆分成多个 默认 自定义硬件…

NineData云原生智能数据管理平台新功能发布|2024年11月版

本月发布 8 项更新&#xff0c;其中重点发布 2 项、功能优化 6 项。 重点发布 数据库 Devops - 数据生成支持多个数据源 NineData 支持在数据库中自动生成符合特定业务场景的随机数据&#xff0c;用于模拟实际生产环境中的数据情况&#xff0c;帮助用户在不使用真实数据的情况…