初步尝试 tauri,并且与 electron.js 对比

sxkk20082年前知识分享238

什么是 Tauri?

Tauri 是一个为所有主流桌面平台构建小型、快速二进制文件的框架。开发人员可以集成任何编译成 HTML、 JS 和 CSS 的前端框架来构建他们的用户界面。应用程序的后端是一个 Rust 二进制文件,具有前端可以与之交互的 API。

image.png

在 2021 年 star 排行榜单中,tauri 一年增长了 18k 排名第五,我们就很好奇,Tauri 有什么优势呢?

然后我分别用 tauri 和 Electron.JS 打包测试一个 hello world 程序,一起来看下它们的大小。

大小对比

  • Electron.JS 62.5mb
  • Tauri 4.32mb

Tauri 构建的桌面程序太小了,远不是 Electron.JS 可以相比的,因为它放弃了体积巨大的  Chromium 内核   和  nodejs,前端使用操作系统的  webview,后端集成了  Rust。 Tauri 提供了初始化程序的模板,比如原生 js, react, svelte.js, vue.js 等等。

image.png

MOBILE when? 这条 issues 看, Tauri 团队也正在努力支持 Android and IOS.这是不是有点小期待呢?

开始尝试 Tauri

因为 Tauri 是一个多语言的工具链,涉及安装有点复杂。

我这边是 macos 系统

1、 首先要安装 gcc 编译器

$ brew install gcc

homebrew 可以先切换清华大学的源, 需要先安装 homebrew, 下面命令是 homebrew 的国内安装地址

安装 homebrew

/bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)"

2、 确保已经安装 xcode

xcode-select --install

3、安装 Nodejs 运行环境 和包管理工具 yarn

这一步前端都已经装了

4、安装是 Rust 编程语言的编译器 rustc

$ curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

image.png

然后就可以使用官方 cli 初始化程序了。

yarn create tauri-app

image.png

然后要在项目目录下初始化

yarn tauri init

image.png

这一步骤很慢,我不清楚是否是我没指定 rust 国内源,知道的小伙伴可以在评论区留言。 完成之后执 yarn start 就跟开发 react 程序一样,就可以实时热更新了。

image.png

第一次运行这个命令时,Rust 包管理器需要几分钟时间下载并构建所有需要的包,后续的构建会快得多,因为它们是有缓存的。

客户端开发启动命令

yarn tauri dev

右键也可以审查元素

image.png

打包客户端

yarn tauri build

image.png

与 Electron 对比

我们可以通过官方 github Readme 查看与 electron 对比

Comparison between Tauri and Electron

详细TauriElectron
安装包大小 Linux3.1 MB52.1 MB
内存消耗 Linux180 MB462 MB
启动时间 Linux0.39s0.80s
界面服务提供WRYChromium
后端绑定RustNode.js (ECMAScript)
潜在引擎RustV8 (C/C++)
FLOSSYesNo
多线程YesYes
字节码交付YesNo
多多窗口YesYes
自动更新YesYes1
自定义 App IconYesYes
Windows BinaryYesYes
MacOS BinaryYesYes
Linux BinaryYesYes
iOS BinarySoonNo
Android BinarySoonNo
Desktop TrayYesYes
Sidecar BinariesYesNo

小结

这次尝试,只是从 web 层,并没有涉及系统 后端,需要学一些 rust 相关的知识。若单纯 web 程序打包,使用 tauri 会更小,若熟悉 node.js api 的还是推荐 electron.js ,毕竟 vscode 这么大的程序也是 electron.js 构建的。

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

相关文章

AI语音识别:携手新媒体,改变未来的交流方式

AI语音识别:携手新媒体,改变未来的交流方式

  随着科技的不断进步,人工智能在我们的日常生活中扮演着越来越重要的角色。而在新媒体领域,AI语音识别更是一项重要且引人注目的技术。通过结合AI与语音识别技术,我们能够极大地...

AI识别技术:从概念到应用的全面解析

AI识别技术:从概念到应用的全面解析

  人工智能(AI)技术在近年来得到广泛的关注和应用,其中AI识别技术作为其重要组成部分,已经在多个领域展现出巨大的潜力。本文将对AI识别技术进行全面解析,包括其概念、原理、...

人工智能改变生活,预测未来生活将变成什么样?

人工智能改变生活,预测未来生活将变成什么样?

  人工智能(AI)作为一种新兴技术,正在改变着我们的生活方式。随着科技的不断发展,越来越多的人工智能应用进入到我们的日常生活中,其中包括我们生活中的网购、社交、出行、医疗甚...

人工智能机器人:现实与未来的展望

人工智能机器人:现实与未来的展望

  随着人工智能技术的快速发展,人工智能机器人正成为我们日常生活中的重要一环。这些机器人不仅仅是我们的助手,更是我们的伙伴和朋友。本文将深入探讨人工智能机器人的现状和未来展望...

一天内筛选超1亿种化合物,AI语言模型“提速”药物发现

一天内筛选超1亿种化合物,AI语言模型“提速”药物发现

  美国麻省理工学院和塔夫茨大学研讨人员设计出一种依据大型言语模型(如ChatGPT)的人工智能算法,这种称为ConPLex的新模型可将方针蛋白与潜在的药物分子相匹配,而无需...

https://retor.hr/

https://sedeblockchain.com/

https://dnaprojecten.nl/

web design trend 2023 example 1 https://nationalstudentshow.com/

https://anakaric.com/

https://yaremenko.design/

https://www.landa.as/es/

web design trend 2023 example https://selectedbase.com/

CSS First

在过去,我们通常依靠 JavaScript 来创造网站的视觉效果。但从那时起,CSS 已经发展到可以做很多复杂的事情,而这些事情是 JavaScript 无法做到的。三维变换、过滤器和新的 CSS 功能,如:选择器(has)、容器查询(@container)和层叠层(@layer),将使许多有趣的网页设计纯粹依靠 CSS 来实现。

因此,从今年开始,我们将看到网站减少对 JavaScript 的依赖来创造视觉效果。

https://redstapler.co/cool-css-text-light-effect-5-minutes-tutorial/

https://redstapler.co/3d-infinity-effect-css-tutorial/

https://codepen.io/seyedi/pen/zYoeLEv

3d transparent video https://redstapler.co/create-3d-effect-on-website-using-transparent-video-background/

2023 web 设计趋势

翻译一篇文章原文链接:https://redstapler.co/web-design-trends-2023/作者:TK在过去的一年里,我们在网页设计领域看到了很多令人兴奋的发展。而在这篇文章中,我...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。