Tauri 2.0 深度体验:前端开发者的跨平台新选择

Tauri 2.0 深度体验:前端开发者的跨平台新选择

logo 辉小志
Tauri跨平台开发前端开发Rust移动端开发

深入探讨 Tauri 2.0 在跨平台应用开发中的优势与实践经验,从实际项目出发,分享开发心得与注意事项,助力前端开发者打造全平台应用。

移动端还是桌面端?这个困扰许多开发者的选择题,在 Tauri 2.0 的发布后终于有了完美解答 —— 我们可以都要!

作为一名前端开发者,当需要开发跨平台应用时,往往要在多个技术方案中权衡:

  • Electron/Wails 只支持桌面端 (Windows/MacOS/Linux)
  • Capacitor/UniApp 局限于移动端 (Android/iOS)
  • Flutter 虽然全平台支持,但需要学习完全不同的技术栈
  • 为每个平台开发原生应用,则是更加极客的选择

而 Tauri 2.0 的到来,让这个局面发生了改变。它实现了真正的全平台支持,成为目前市面上唯一一个让前端开发者能够使用熟悉的技术栈 (HTML、CSS、JavaScript/TypeScript),同时构建 Windows、MacOS、Linux、Android 和 iOS 应用的开发框架。

当然,Tauri 也并非完美无缺。最明显的就是无法直接开发小程序,这在小程序普及率极高的国内市场确实是个限制。不过,这个问题其实有解决方案 —— 将 Tauri 2.0 与 UniApp 结合使用:使用 Vue 开发界面,用 UniApp 编译成各类小程序和 H5 版本,再用 Tauri 2.0 打包 H5 版本。这样就能实现真正的”一套代码,处处运行”。

另一个经常被提到的问题是样式兼容性。确实,不同平台上某些 CSS 属性可能会有差异。但根据我的实际开发经验,这些问题都是可以轻松解决的。稍作修改就能让样式在各个平台正常工作,完全不影响使用。在这里我要特别提醒开发者们:不要被网上的一些言论吓到,就像“小马过河”一样,到底适不适合自己,还是要亲自试过才知道。

分享一下我的实际开发经验。我目前开发的“批量背单词”APP,已上架苹果应用商店Android 版也已经可以从我的官网下载,等软著下来之后,就会上架各大应用商店。

“批量背单词”采用了一个相对轻量级的方案:大部分功能都在前端实现,数据存储使用 Dexie(一个 IndexDB 的封装库) 将数据存储在 WebView 中,而不是通过 Rust 存储在本地。我强烈推荐这种方案,除非你有必须将数据存储在本地的特殊需求,否则前端存储完全够用,这样可以大大简化开发流程。事实上,这个 APP 我完全没有写过一行 Rust 代码!

当然,Rust 端依然是 Tauri 的一大优势。我之前开发过一个叫 Liveship 的项目,是用 FFmpeg 录制直播视频的应用,大部分核心逻辑都在 Rust 端实现。虽然 Rust 的学习曲线相对陡峭,但它确实非常强大,而且有大量优质的第三方包可用。如果你的应用需要处理复杂的本地运算、文件操作等功能,Rust 绝对是你的得力助手。

对于想要进入跨平台应用开发领域的前端开发者来说,Tauri 2.0 是一个极具潜力的选择。它不仅降低了开发门槛,还提供了覆盖全平台的解决方案。更重要的是,它的灵活性让开发者可以根据实际需求选择开发策略:可以完全依赖前端技术栈,也可以充分利用 Rust 的强大能力。

如果你也对跨平台应用开发感兴趣,欢迎下载体验我的作品“批量背单词”。我也会持续关注 Tauri 的发展,分享更多开发经验。

相信随着 Tauri 2.0 的发展成熟,会有越来越多优秀的应用诞生。让我们一起期待这个“一次开发,处处运行”的美好未来。