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

Hello, Tauri!

前言

之前用 python 做了两个软件,被吐槽最多的就是软件包体较大,占用了较多的硬盘空间。

主要原因是 python 是一门解释型语言,在打包应用时,必须把 Python 解释器打包进去。

此外,PyInstaller 之类的打包工具又采用了保守的打包策略,打包时会默认包含所有依赖,导致包体进一步增大。

负负相乘,导致依赖一多 python 应用,没有几百MB的体积,无法运行。

尽管有 nuitka 之类的编译型打包工具,但速度极慢,稳定性也欠佳。

因此,决定拓展一下技术栈,学习一下目前主流的Rust+Tauri的开发流,它们具有如下优势:

项目RustTauri
语言层面安全、快速、无GC用 Rust 编写核心,安全
性能接近 C/C++打包体积小、运行快
安全性编译期保障权限隔离机制
构建工具cargo 强大统一与 Web 打包工具融合
跨平台一次开发,多平台部署多平台桌面开发
社区趋势最受欢迎语言之一Electron 替代者、生态快速增长

Tauri 是什么?

Tauri 是一个用于为所有主流桌面(macOS、linux、windows)和移动(iOS、Android)平台构建微小而快速的二进制文件的框架。

开发人员可以集成任何编译为 HTML、JavaScript 和 CSS 的前端框架来构建用户体验,同时在需要时利用 Rust、Swift 和 Kotlin 等语言实现后端逻辑。

Tauri 有三个主要优势:

  • 构建应用所需的可靠基础
  • 使用系统原生 webview(网页视图)带来的更小打包体积
  • 使用任何前端技术和多种语言绑定带来的灵活性

官方文档:https://v2.tauri.app/zh-cn/start/prerequisites

环境安装

1. 检查 WebView2 安装情况

以 windows 开发环境为例,tauri需要依赖 WebView2 进行UI渲染,该依赖自 Windows 10(从版本 1803 开始)默认安装,正常情况无需再次安装。

2. 安装 Rust

通过 Rust 官网安装 Rust:

官网地址:https://www.rust-lang.org/zh-CN/tools/install

3. 安装 Tauri CLI

使用 Rust 自带的包管理和构建工具 cargo 进行安装:

cargo install tauri-cli --locked

4. 安装 Tauri 项目初始化工具

cargo install create-tauri-app --locked

启动第一个应用

使用 cargo 创建应用:

cargo create-tauri-app

创建时,会弹出一步步提示,最后一步选择前端框架,有以下可选项:

框架特点说明
Vanilla (无框架)最轻量,纯 HTML/CSS/JS,适合有性能要求或自建框架的开发者
ReactFacebook 维护,组件化强大,生态成熟,适合大型项目
Vue上手快,语法简洁,模板逻辑分离好,适合中小项目或快速迭代
Svelte编译时框架,运行时更小更快,开发体验极佳
Solid新兴高性能框架,类似 React 但无虚拟 DOM,极小体积
Next.js基于 React 的 SSR 框架,适合你想构建网页/桌面混合项目(实验性)
Nuxt.jsVue 的 SSR 框架,同上,支持 SEO / 服务端渲染(实验性)

编译启动应用:

cargo tauri dev

打包应用:

cargo tauri build

应用体积 8.34MB。

而且打包完之后,它顺便生成了 msi 和 exe 两种形式的安装包,比 pyinstaller 还需要编辑 spec 文件相比,实在太解手。

项目结构

整体项目结构如下,前后端很清晰。

Project/                        # 项目根目录
├── README.md                   # 项目说明文档
├── src/                        # 前端资源目录
│   ├── assets/                 # 静态资源(如图片、SVG等)
│   ├── index.html              # 前端主页面
│   ├── main.js                 # 前端主JS逻辑
│   └── styles.css              # 前端样式表
├── src-tauri/                  # Tauri 后端相关目录
│   ├── build.rs                # Rust 构建脚本
│   ├── capabilities/           # Tauri 权限配置
│   ├── Cargo.lock              # Rust 依赖锁定文件
│   ├── Cargo.toml              # Rust 依赖与项目信息
│   ├── gen/                    # 生成代码目录(可能为空或自动生成)
│   ├── icons/                  # 应用图标资源
│   ├── src/                    # Rust 源码目录
│   ├── target/                 # Rust 编译输出目录
│   └── tauri.conf.json         # Tauri 配置文件

总结

初步体验 Tauri,感觉上手起来难度不高,兼容各种前端框架意味着样式的自由度会很高。后面计划采用这套技术栈开发一些有意思的小工具。

http://www.dtcms.com/a/279755.html

相关文章:

  • 基于Android的景点旅游信息系统App
  • 使用aiohttp实现高并发爬虫
  • uni-app开发的页面跳转全局加载中
  • 基于HarmonyOS的智能灯光控制系统设计:从定时触发到动作联动全流程实战
  • C++ 中常见的字符串定义方式及其用法
  • 1111自己
  • 基础分类模型及回归简介(一)
  • 体验RAG GitHub/wow-rag
  • 前端同学,你能不能别再往后端传一个巨大的JSON了?
  • 引用(C++)
  • python的微竞网咖管理系统
  • ⽂本预处理(一)
  • volatile 关键字
  • Codeforces Round 787 (Div. 3)(A,B,C,D,E,F,G)
  • DO,VO,DTO.....
  • (二十四)-java+ selenium自动化测试-三大延时等待
  • UI前端与数字孪生融合案例:智慧城市的智慧停车引导系统
  • 苍穹外卖Day4
  • JavaScript进阶篇——第二章 高级特性核心
  • vue笔记4 vue3核心语法和pinia基础使用
  • 【leetcode】326. 3的幂
  • VSCode中使用容器及容器编排docker-compose
  • L1与L2正则化详解:原理、API使用与实践指南
  • FastAPI + gRPC 全栈实践:Windows 开发到 Ubuntu 部署全指南
  • JVM监控及诊断工具-命令行篇
  • ubuntu 22.04 anaconda comfyui安装
  • 8.数据库索引
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘collections’问题
  • WIFI MTU含义 ,协商修改的过程案例分析
  • ansys2021R Fluent 的UDF配置问题