位置: 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破解授权)

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

  • oppok9pro怎么设置息屏显示(oppok9pro怎么设置返回键)

    oppok9pro怎么设置息屏显示(oppok9pro怎么设置返回键)

  • 我的宁夏健康码黄色怎么变成绿色(我的宁夏健康码怎么切换另一个人)

    我的宁夏健康码黄色怎么变成绿色(我的宁夏健康码怎么切换另一个人)

  • 腾讯自动扣费能退回吗(腾讯自动扣费能申请退款吗)

    腾讯自动扣费能退回吗(腾讯自动扣费能申请退款吗)

  • 如何取消华为应用市场安全检测(如何取消华为应用市场密码)

    如何取消华为应用市场安全检测(如何取消华为应用市场密码)

  • 网易云音乐扫一扫在哪里(网易云音乐扫一扫在哪里安卓)

    网易云音乐扫一扫在哪里(网易云音乐扫一扫在哪里安卓)

  • 华为mate30pro自动重启是什么原因(华为mate30pro自动横屏怎么设置)

    华为mate30pro自动重启是什么原因(华为mate30pro自动横屏怎么设置)

  • 抖音关注上限是多少(抖音关注上限是5000还是1万)

    抖音关注上限是多少(抖音关注上限是5000还是1万)

  • oppor17怎么恢复出厂系统(oppor17怎么恢复微信聊天记录)

    oppor17怎么恢复出厂系统(oppor17怎么恢复微信聊天记录)

  • 苹果哪些机型有nfc(苹果哪些机型有灵动岛)

    苹果哪些机型有nfc(苹果哪些机型有灵动岛)

  • wifi一会能用一会不能用怎么回事(wifi一会能用一会感叹号)

    wifi一会能用一会不能用怎么回事(wifi一会能用一会感叹号)

  • 怎样取消QQ群冻结期(qq群冻结后怎么解散)

    怎样取消QQ群冻结期(qq群冻结后怎么解散)

  • 抖音上收藏的表情包在哪(抖音上收藏的表情包怎么删除)

    抖音上收藏的表情包在哪(抖音上收藏的表情包怎么删除)

  • qq送礼物可以提现吗(qq里面送礼物提现的钱去哪里了)

    qq送礼物可以提现吗(qq里面送礼物提现的钱去哪里了)

  • gb与mb哪个流量大(gbmb哪个流量大)

    gb与mb哪个流量大(gbmb哪个流量大)

  • 什么浏览器支持flash插件(什么浏览器支持icloud官网)

    什么浏览器支持flash插件(什么浏览器支持icloud官网)

  • 手机刷屏步骤(手机刷屏步骤苹果版)

    手机刷屏步骤(手机刷屏步骤苹果版)

  • 红米note8怎么设置一键锁屏(红米note8怎么设置返回键)

    红米note8怎么设置一键锁屏(红米note8怎么设置返回键)

  • ios13的设备管理在哪(ios13.3设备管理在哪)

    ios13的设备管理在哪(ios13.3设备管理在哪)

  • 如何创建脚本文件(如何创建脚本文件myscript)

    如何创建脚本文件(如何创建脚本文件myscript)

  • 三星人工智能叫什么(三星人工智能叫什么怎么读)

    三星人工智能叫什么(三星人工智能叫什么怎么读)

  • 抖音尬舞机在哪里打开(尬舞机怎么找不到了)

    抖音尬舞机在哪里打开(尬舞机怎么找不到了)

  • 移动视频彩铃什么意思(移动视频彩铃业务)

    移动视频彩铃什么意思(移动视频彩铃业务)

  • iphone xs max有nfc吗(iPhone XS Max有NFC吗)

    iphone xs max有nfc吗(iPhone XS Max有NFC吗)

  • 微信怎么发布招聘信息(微信怎么发布招商广告)

    微信怎么发布招聘信息(微信怎么发布招商广告)

  • 努沙杜瓦海岸与防波堤,印度尼西亚巴厘岛 (© Dkart/Getty Images)(努沙杜瓦酒店)

    努沙杜瓦海岸与防波堤,印度尼西亚巴厘岛 (© Dkart/Getty Images)(努沙杜瓦酒店)

  • Three.js教程:材质效果(three.js 入门)

    Three.js教程:材质效果(three.js 入门)

  • 销项税额和进项税额发票怎么区别
  • 给客户开增值税专用发票
  • 红冲以前年度收入成本的账务处理
  • 电子税务局怎么删除办税员
  • 坏账准备计提比率计算公式
  • 购买方怎么写分录
  • 旅游企业增值税优惠政策
  • 以合并方式成立的新企业,新启用
  • 年金终值的公式
  • 出口转内销补交关税
  • 事业单位为职工代扣代缴个人所得税
  • 结转周转材料成本差异会计分录
  • 原材料做成库存会计分录
  • 免费拿样品
  • 一般纳税人每个月需要报哪些税
  • 一般纳税人开6个点的票内容
  • 个人所得税怎么查工资明细
  • 一个公司可以有几个公章
  • 稳岗补贴会计怎么做账
  • 预缴和实际应付的区别
  • 没有预付账款科目计入哪里
  • 购进生产用原材料,取得增值税专用发票注明税额25600元
  • 什么情况哦
  • win10怎么手动修改时间
  • 出口货物做内销处理
  • nod32kui.exe - nod32kui是什么进程 作用是什么
  • 进项税年末需要结转么
  • 已经认证抵扣的发票,发生冲红,要怎么处理
  • 收到退回的保证金
  • 期货保证金的计算公式当日盈亏怎么算
  • 艾叶泡脚的功效与作用及禁忌
  • 旅游企业会计ppt
  • 蓝山公馆的房子怎么样
  • 无形资产摊销是按原值吗
  • smarty怎么用
  • 工具合集
  • php数组降序排列
  • timeout&f
  • 百度怎么自动下载视频
  • 会计账簿记账规则最新
  • 收到汽车会计分录
  • python缩进有什么作用
  • 税控发票如何入账
  • 筹建期购买办公用品
  • 企业其他应收款包括哪些
  • db2常用操作语句
  • mysql从一个库导入进另一个库
  • 公司优秀党员奖章
  • 本期盈余转入累计盈余
  • 一般纳税人开普票和专票有什么区别
  • 运输中合理损耗计入什么科目
  • 长期借款计提的利息可能借记
  • 银行开手续费发票怎么做账
  • 特殊销售方式下的销售额确认图文怎么做
  • 营业费用包括哪些?
  • 装修费用摊销是指什么
  • 建账的基本要求
  • 新企业的创建
  • sqlserver日志已满
  • mac怎么复制文件路径地址
  • win7系统的启动项在哪里
  • mac安装mysql详细教程
  • 在u盘里装win7
  • explorer.exe进程在哪
  • win8系统如何关机
  • 电脑kernel32.dll
  • win10推送升级win11
  • 消除类策略游戏
  • js正则用法
  • 如何理解闭包,闭包的优缺点
  • js中的onchange
  • u3d unity3d
  • JavaScript焦点事件、鼠标事件和滚轮事件使用详解
  • javascript基础入门教程
  • json对象结构中,关键字key必须为什么类型
  • python3连接pg执行命令
  • 土地闲置是否需要缴纳土地使用税
  • 内蒙古物业费收取标准2020
  • 进口设备如何交税
  • 甘肃省国家税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设