位置: IT常识 - 正文

Tauri+Rust+Vue 跨平台桌面应用简明教程(1)环境创建+系统事件+自定义菜单(rust 前端开发)

编辑:rootadmin
作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功、JAVA底层、面试相关资料等更多精彩文章在公众号「小牛呼噜噜 」 Tauri简介 Tauri 是一个工具包,可以帮助开发者为主要桌面平台制作应用程序(如 mac,windows,linux 等)。几乎支持现有的任何 ...

推荐整理分享Tauri+Rust+Vue 跨平台桌面应用简明教程(1)环境创建+系统事件+自定义菜单(rust 前端开发),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vulkan rust,rust跨平台编译,vulkan rust,rust做web后端,rust调用js,rust写前端,rust跨平台编译,rust 跨平台gui,内容如对您有帮助,希望把文章链接给更多的朋友!

作者:小牛呼噜噜 | https://xiaoniuhululu.com计算机内功、JAVA底层、面试相关资料等更多精彩文章在公众号「小牛呼噜噜 」

Tauri简介

Tauri 是一个工具包,可以帮助开发者为主要桌面平台制作应用程序(如 mac,windows,linux 等)。几乎支持现有的任何前端框架(如 react, vue, vite 等),其核心是使用 Rust 编写的。类似Electron的GUI框架,相比于 Electron,其突出优点就是体积小。我们知道Electron 相当于是打包了一个小型浏览器,体积比较大,还占内存。而 Tauri 开发的应用,前端使用操作系统的 webview,后端集成了 Rust,理论上性能杠杠的,使得打包后的体积相当小。空壳项目Electron 打包的应用大概在 50 M,而 Tauri 只有 4 MB左右。

本文就来尝尝鲜,踩踩坑,顺便和Rust编译器作作斗争!

环境准备

本文只介绍 Windows10下的准备工作,其他环境大家得自行去官网查看https://tauri.app/zh/v1/guides/getting-started/prerequisites

安装Microsoft Visual Studio C++ 生成工具

我们需要安装 Microsoft C++ 生成工具。 其实最简单的方法是下载 Visual Studio 2022 生成工具。 进行安装选择时,请勾选 "C++ 生成工具" 和 Windows 10 SDK。

安装路径自行选择即可

WebView2

Windows 11 已预装了 WebView2

Tauri 需要 WebView2 才能在 Windows 上呈现网页内容,小牛的电脑 还是win10,需要自行去微软网站https://developer.microsoft.com/zh-cn/microsoft-edge/webview2/#download-section上下载和运行常青版引导程序安装脚本会自动为您下载适合您架构的版本。 不过,如果您遇到问题 (特别是 Windows on ARM),您可以自己手动选择正确版本。

Rust

Microsoft Visual Studio C++安装完成后,Rust 所需的 msvc 命令行程序需要手动添加到环境变量中,否则安装 Rust 时 rustup-init 会提示未安装 Microsoft C++ Build Tools,其位于:%Visual Studio 安装位置%\VC\Tools\MSVC\%version%\bin\Hostx64\x64(自行替换其中的 %Visual Studio 安装位置%、%version% 字段)下。

最后需要前往 https://www.rust-lang.org/zh-CN/tools/install 来安装 rustup (Rust 安装程序)。 请注意,为了使更改生效,您必须重新启动终端,在某些情况下需要重新启动 Windows 本身。

在 https://www.rust-lang.org/zh-CN/learn/get-started下载系统相对应的 Rust 安装程序,一路默认即可。

检查是否安装成功:

C:\windows\system32>rustup -Vrustup 1.24.3 (ce5817a94 2021-05-31)info: This is the version for the rustup toolchain manager, not the rustc compiler.info: The currently active `rustc` version is `rustc 1.61.0 (fe5b13d68 2022-05-18)`创建项目

我们还是走的官网推荐的create-tauri-app项目

cargo install create-tauri-appcargo create-tauri-appTauri+Rust+Vue 跨平台桌面应用简明教程(1)环境创建+系统事件+自定义菜单(rust 前端开发)

然后需要选择,npm 包管理器,因为想使用vue-ts

E:\Halo>cargo create-tauri-app✔ Project name · tauri-app-project-study✔ Choose your package manager · npm✔ Choose your UI template · vue-tsPlease follow https://tauri.app/v1/guides/getting-started/prerequisites to install the needed prerequisites, if you haven't already.Done, Now run: cd tauri-app-project-study npm install npm run tauri dev

最后把 终端提示的命令依次执行完即可

cd tauri-app-project-studynpm installnpm run tauri dev

成功运行项目:

至此,一个新的 Tauri 项目已创建完成,我们使用vscode进行后续的开发

项目结构

项目结构除了多一个src-tauri(这个是rust项目),其他的基本和vue项目结构一样

添加关闭提示

下面我们就简单实现关闭提示的系统事件,来演示一下,tauri 和 rust 配合的效果打开src/main.rs,我们发现

此处有个爆红,我们只需在根目录下,创建dist文件夹即可让此处不再爆红

#![cfg_attr( all(not(debug_assertions), target_os = "windows"), windows_subsystem = "windows")]//use tauri::window;//Learn more about Tauri commands at https://tauri.app/v1/guides/features/command#[tauri::command]fn greet(name: &str) -> String { format!("Hello, {}! You've been greeted from Rust!", name)}fn main() { tauri::Builder::default()//新增关闭提示的逻辑 .on_window_event(|event|{ match event.event() { tauri::WindowEvent::CloseRequested { api, .. } =>{ //阻止默认关闭 api.prevent_close(); let window = event.window().clone(); tauri::api::dialog::confirm(Some(&event.window()), "关闭应用", "确定关闭当前应用?", move| answer|{ if answer { window.close(); } }) }, _ => {}//todo } }) .invoke_handler(tauri::generate_handler![greet]) .run(tauri::generate_context!()) .expect("error while running tauri application");}

如果我们最后只写window.close();,编译器会报:unused Result that must be used,this Resultmay be an Err variant, which should be handled就是说这个rust中对于返回值为Result类型的函数,调用方如果没有进行接收,编译期会产生警告

let _result =window.close();//直接接收一下即可,_表示让浏览器忽略未使用的变量

添加自定义菜单

我们就直接用官网的实例,来演示一下了,修改main.rs

use tauri::{Menu, MenuEntry, Submenu, MenuItem};fn main() { tauri::Builder::default() //新增菜单 .menu(Menu::with_items([ MenuEntry::Submenu(Submenu::new( "File", Menu::with_items([ MenuItem::CloseWindow.into(), #[cfg(target_os = "macos")] CustomMenuItem::new("hello", "Hello").into(), ]), )), ])) .on_window_event(|event|{ match event.event() { tauri::WindowEvent::CloseRequested { api, .. } =>{ //阻止默认关闭 api.prevent_close(); let window = event.window().clone(); tauri::api::dialog::confirm(Some(&event.window()), "关闭应用", "确定关闭当前应用?", move| answer|{ if answer { let _result =window.close(); } }) }, _ => {}//todo } }) .invoke_handler(tauri::generate_handler![greet]) .run(tauri::generate_context!()) .expect("error while running tauri application");}

效果:

本文就先到这里啦,后面我们继续更新tauri+rust更多有意思的特性

参考资料:https://tauri.app/zh/v1/guides/distribution/windows

本篇文章到这里就结束啦,很感谢你能看到最后,如果觉得文章对你有帮助,别忘记关注我!更多精彩的文章

本文链接地址:https://www.jiuchutong.com/zhishi/312004.html 转载请保留说明!

上一篇:帝国CMS功能解密之字段处理函数详解(帝国cms破解授权)

下一篇:注册有赞微小店教程,用于织梦个人支付(有赞微小店认证麻烦)

  • 华为nova9pro怎么设置电池百分比(华为nova9pro怎么关闭5G网络)

    华为nova9pro怎么设置电池百分比(华为nova9pro怎么关闭5G网络)

  • iphone11主号副号怎么切换(苹果11主号副号)

    iphone11主号副号怎么切换(苹果11主号副号)

  • nova 5pro耳机孔在哪里(nova5ipro耳机插口)

    nova 5pro耳机孔在哪里(nova5ipro耳机插口)

  • 电脑菜单栏变成竖的了(电脑菜单栏变成竖的了怎么调回来)

    电脑菜单栏变成竖的了(电脑菜单栏变成竖的了怎么调回来)

  • 腾讯会议可以关闭摄像头吗(腾讯会议可以关闭别人的摄像头吗)

    腾讯会议可以关闭摄像头吗(腾讯会议可以关闭别人的摄像头吗)

  • 滴滴活跃度怎么提升(滴滴活跃度怎么提升快)

    滴滴活跃度怎么提升(滴滴活跃度怎么提升快)

  • rne al00是什么型号(rne一al00是什么型号)

    rne al00是什么型号(rne一al00是什么型号)

  • adsl拨号上网什么意思(adsl是拨号上网吗)

    adsl拨号上网什么意思(adsl是拨号上网吗)

  • 手机漏液怎么办(手机漏液怎么办解决)

    手机漏液怎么办(手机漏液怎么办解决)

  • 手机停用连接itunes是什么原因(手机停用连接itunes要多少钱)

    手机停用连接itunes是什么原因(手机停用连接itunes要多少钱)

  • 对方已取消什么意思(ᯅ对方已取消)

    对方已取消什么意思(ᯅ对方已取消)

  • 抖音时间怎么延长5分钟(抖音时间怎么延长到50秒)

    抖音时间怎么延长5分钟(抖音时间怎么延长到50秒)

  • 开启内存xmp会伤电脑吗(内存开启xmp好处和坏处)

    开启内存xmp会伤电脑吗(内存开启xmp好处和坏处)

  • 快手注销账号要多久,可以重新注册(快手注销账号要多久才搜索不到)

    快手注销账号要多久,可以重新注册(快手注销账号要多久才搜索不到)

  • b-g7电池是什么型号vivo(b_g6电池)

    b-g7电池是什么型号vivo(b_g6电池)

  • 小米的智能精灵叫什么(小米智能精灵怎么称呼它)

    小米的智能精灵叫什么(小米智能精灵怎么称呼它)

  • 微信头像上的圣诞帽怎么弄(微信头像的圣诞帽怎么取消)

    微信头像上的圣诞帽怎么弄(微信头像的圣诞帽怎么取消)

  • 切换中英文输入法的快捷键(切换中英文输入方式的快捷键)

    切换中英文输入法的快捷键(切换中英文输入方式的快捷键)

  • word文档出现蓝色字体(word文档出现蓝色双线是什么意思)

    word文档出现蓝色字体(word文档出现蓝色双线是什么意思)

  • 电脑回收站在哪里打开(电脑回收站在哪win10)

    电脑回收站在哪里打开(电脑回收站在哪win10)

  • 华为nova3几个卡槽(华为nova3e几个卡槽)

    华为nova3几个卡槽(华为nova3e几个卡槽)

  • 嗨来电怎么设置不了(嗨来电怎么设置来电闪光灯)

    嗨来电怎么设置不了(嗨来电怎么设置来电闪光灯)

  • iphonexr港版支持双卡吗(iphonexr港版可以用电信卡吗)

    iphonexr港版支持双卡吗(iphonexr港版可以用电信卡吗)

  • y97支持指纹支付吗(y97支持指纹解锁吗?)

    y97支持指纹支付吗(y97支持指纹解锁吗?)

  • 苹果手机4g网速慢怎么办(苹果手机4G网速突然变慢)

    苹果手机4g网速慢怎么办(苹果手机4G网速突然变慢)

  • vivox3返回键在哪里(vivo y3s返回键)

    vivox3返回键在哪里(vivo y3s返回键)

  • 小米9otg功能在哪里打开(小米9OTG功能在哪)

    小米9otg功能在哪里打开(小米9OTG功能在哪)

  • 一般户付款能开增值税票吗
  • 货物或应税劳务服务名称怎么填
  • 税额四舍五入的计算公式
  • 投资性房地产在非货币性资产交换怎么处理
  • 与企业日常无关的政府补服属于利得吗
  • 个税系统异常怎么申报
  • 固定资产怎么进账
  • 韩国购物小票怎么看图解
  • 违约金收入是否征税
  • 运输业务增值税
  • 如何设置采购入库的对方科目暂估科目
  • 分类账和明细账平行登记规则
  • 小规模纳税人财务报表是按季还是按月申报
  • 结转库存商品会计分录
  • 当月采购发票未到如何做账及结转成本?
  • 企业收不回款项计入什么科目?
  • 成本大于收入可以吗
  • 房地产公司工程管理制度
  • 事业单位职工福利费计提标准和使用
  • 奖金多发退回时间怎么算
  • 向消费者支付佣金怎么算
  • 增值税专票电话号码错了有关系吗
  • 合同中补充协议
  • 营改增后如何纳税
  • 异地业务操作
  • 关于不动产进项税额分期抵扣的新政策,以下不属于
  • 本年利润怎么算利润总额
  • 外商企业需要交企业所得税吗
  • 公司招聘费属于什么科目
  • 暂估入库的货物销售了当月多交增值税了
  • 税票认证节假日可以顺延吗?
  • 行程单的金额怎么算
  • 商品条码续展费怎么退
  • Win11系统怎么更换桌面壁纸
  • 为什么我的win10
  • 没有系统U盘,电脑密码忘记了如何打开电脑
  • Win11如何卸载microsoft edge浏览器
  • 增值税的计税依据包括契税吗
  • Micheldever Wood的蓝铃花,英国汉普郡 (© Hursley/Getty Images Plus)
  • 不能抵扣的发票可以做成本吗
  • 无偿赠送增值税问题
  • 其他应收款超过一年是12个月吗?
  • 窗函数的作用
  • 人工智能aima
  • 华侨是否适用个人所得税
  • vue切换背景图片
  • 用smart原则改写年底前完善客户资料
  • 强制缓存与协商缓存的区别
  • js防抖函数和节流函数
  • php封装app
  • 帝国cms是基于什么的
  • 银行会计核算方法的特点
  • 小微企业增值税减免政策
  • 医疗机构销售药品是否征收增值税
  • 发票报销哪些要素不能少
  • 最新版税控盘怎么设置打印机
  • 应收账款余额贷方
  • 小规模纳税人企业所得税2023
  • 什么叫印花税税率
  • 预付账款可以开发票吗
  • 原材料采购未入库会计分录
  • 营改增后建筑业开票规定
  • 发票提前开能入费用吗?
  • 会计计算工资的步骤流程
  • mac下安装python
  • 教你设置陌陌耳返
  • win7无法登录qq
  • inc是什么软件
  • Win7登录密码
  • win7系统怎么设置屏保图片
  • js定时器的两种方法
  • Extjs gridpanel 出现横向滚动条问题的解决方法
  • js的isnan
  • dos命令显示时间
  • jquery实现下拉框
  • android教学
  • Python实现HTTP协议下的文件下载方法总结
  • js cookie存取
  • 社保每个月几号截止申报
  • 核准类和备案类项目
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设