今天在无意间发现了一个新的前端平台框架 Tauri
据说对比electron有许多性能和打包大小等等方面的优化,具体可看github link
由于在环境安装中遇到了坑,这里将官网macOS的安装流程记录下来,并且在相关地方标注注意事项:
1. System Dependencies
`brew install gcc` 安装gcc环境
这里安装gcc的时候博主出现了一些问题,由于`brew cleanup has not been run in 30 days, running now.`
提示,在使用brew安装的时候自动运行,结果与博主之前安装在系统中的hexo冲突,而博主也不想进行任何修改,
这里就可以在gcc安装之前先运行一下`brew cleanup`,之后就正常了。
`xcode-select --install` 安装xcode命令行插件
2. Node.js
官方推荐nvm进行相关安装,相关教程可以去这里看NVM。直接nvm install node --latest-npm
安装node最新版即可,这里略去不讲
3. Rustc and Cargo
`curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh`
可以使用`rustc --version`命令查看是否安装完成。
如果已经有Rustc则使用`rustup update stable`命令进行版本的更新。
4. Tauri Bundler
`cargo install tauri-bundler --force`进行Tauri Bundler安装。
这里提醒下,在Rustc和Cargo环境安装的时候执行source $HOME/.cargo/env
就不用重新启动命令行了,博主本人mac系统,用户目录下的.bash_profile
文件中的$HOME/.cargo/bin:$PATH
已经被自动加入了。
接下来就是Tauri的安装和配置了。
Tauri的安装和配置
不知道是不是因为博主的mac系统还停留在Mojave 10.14.1版本的缘故,下面的步骤出现了一些很奇怪的问题,这里跟着流程走,进行一一列举:
1、官方建议使用yarn add tauri
或者npm install tauri --save
命令进行tauri的本地安装。(如果在安装tauri的时候出现问题,可以检查一下npm的版本和yarn的版本,是否符合需求,npm至少要12以上)
在这里可能存在的一个坑:安装错误,提示node_modules/sharp组件不存在,但是实际上你去npm install sharp是不管用的,真正的错误是'vips/vips8' file not found
,这是因为缺少了libvips这个处理图片的库,这里提供macOS下的解决方案:brew install vips
。安装过程中可能会出现失败的情况(博主就碰到了qt安装失败),但是确实这并没有关系,也可能是网络原因,重新brew安装vips就好了,友情提示本教材所有下载相关建议挂梯子。
2、安装好后执行yarn tauri init
进行Tauri项目的初始化,yarn tauri info
查看Tauri是否正确安装。
总算是把环境安装好了,使用yarn tauri dev
就可以测试当前的初始项目啦。第一次运行此命令时,Rust软件包管理器将花费几分钟的时间来下载并构建所有必需的软件包。由于已将其缓存,因此后续构建将更快,因为只有Tauri组件需要重建。
现在就可以使用Tauri窗口来开发应用程序啦!
Tauri的打包
Tauri的打包也有些奇葩,不知道是不是官方尚未完善的问题,我这里的tauri-bundler的版本是0.6.1,如果是直接对上文构建的项目进行build的时候,会出现错误:Error: cannot find index.html in "xxxx/dist". Did you forget to build your web code or update the build.distDir in tauri.conf.json?
但是其实在tauri.conf.json文件中已经默认生成在根目录下会创建dist目录,这里解决方法是自己创建一个dist目录,在里面加上index.html文件。
最终生成的app就创建在src-tauri/target/release/bundle
下,相关的可执行app文件和安装文件都有了,可以说是一键生成非常方便了。在我加了简单的helloworld显示打包后的文件大小为5M,下面是相关图显示。