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

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

  • 荣耀30s能支持无线充电吗(华为荣耀30s带不带无线充电功能)

    荣耀30s能支持无线充电吗(华为荣耀30s带不带无线充电功能)

  • 苹果xr微信如何调夜间模式(苹果xr微信如何分身)

    苹果xr微信如何调夜间模式(苹果xr微信如何分身)

  • 显卡8g和6g有什么区别(显卡6gb和8gb有什么区别)

    显卡8g和6g有什么区别(显卡6gb和8gb有什么区别)

  • 微信聊天记录误删怎么找回(微信聊天记录误删)

    微信聊天记录误删怎么找回(微信聊天记录误删)

  • 磁盘占用100%有什么影响(磁盘占用100%是中毒了吗)

    磁盘占用100%有什么影响(磁盘占用100%是中毒了吗)

  • 8p有256g的吗(苹果8p有256g的吗)

    8p有256g的吗(苹果8p有256g的吗)

  • 可以让siri帮忙关机吗(可以让siri帮忙报警吗)

    可以让siri帮忙关机吗(可以让siri帮忙报警吗)

  • 手机屏幕红斑怎么消除(手机屏幕红斑怎么去除)

    手机屏幕红斑怎么消除(手机屏幕红斑怎么去除)

  • mp4与ts格式哪个清晰(ts与mp4哪个好)

    mp4与ts格式哪个清晰(ts与mp4哪个好)

  • 魅族17有没有无线充电(魅族17带nfc吗)

    魅族17有没有无线充电(魅族17带nfc吗)

  • 小米手机充电线叫啥名字(小米手机充电线接口类型)

    小米手机充电线叫啥名字(小米手机充电线接口类型)

  • vivo手机为什么老重启(vivo手机为什么打不了电话)

    vivo手机为什么老重启(vivo手机为什么打不了电话)

  • p10plus支持面部解锁吗(p10plus支持nfc吗)

    p10plus支持面部解锁吗(p10plus支持nfc吗)

  • 苹果x跟xr手机壳一样吗(苹果x跟xr手机壳一样大吗)

    苹果x跟xr手机壳一样吗(苹果x跟xr手机壳一样大吗)

  • i3 3240配什么主板(i3 3240配什么显卡最好)

    i3 3240配什么主板(i3 3240配什么显卡最好)

  • idc服务是什么(idc是服务器吗)

    idc服务是什么(idc是服务器吗)

  • 苹果x能升13系统吗(苹果x能不能升级ios13)

    苹果x能升13系统吗(苹果x能不能升级ios13)

  • i7cpu温度90度会坏吗(i7温度90度会坏吗)

    i7cpu温度90度会坏吗(i7温度90度会坏吗)

  • 淘宝怎么关闭菜鸟驿站(淘宝怎么关闭菜鸟信息)

    淘宝怎么关闭菜鸟驿站(淘宝怎么关闭菜鸟信息)

  • g2810打印机怎么清洗(g2810打印机怎么加墨水)

    g2810打印机怎么清洗(g2810打印机怎么加墨水)

  • wood啥意思(wood是什么意思呢)

    wood啥意思(wood是什么意思呢)

  • 华为畅享10plus有NFC吗(华为畅享10plus有红外线吗)

    华为畅享10plus有NFC吗(华为畅享10plus有红外线吗)

  • xr与8plus的区别(xr和8plus哪个好?)

    xr与8plus的区别(xr和8plus哪个好?)

  • 新苹果手机如何关闭购买服务(新苹果手机如何下载软件?)

    新苹果手机如何关闭购买服务(新苹果手机如何下载软件?)

  • 微信声音设置在哪里调(微信声音设置在哪里调华为)

    微信声音设置在哪里调(微信声音设置在哪里调华为)

  • 华为荣耀10和青春版有什么区别(华为荣耀10青春版配置参数)

    华为荣耀10和青春版有什么区别(华为荣耀10青春版配置参数)

  • 注意力机制(SE,ECA,CBAM,SKNet, scSE,Non-Local,GCNet) Pytorch代码(注意力机制加在CNN的什么位置)

    注意力机制(SE,ECA,CBAM,SKNet, scSE,Non-Local,GCNet) Pytorch代码(注意力机制加在CNN的什么位置)

  • 政府补助利得要交企业所得税吗怎么算
  • 个体户缴纳经营所得个税怎么算的
  • 什么是进口增值税率
  • 集体不动产和动产包括
  • 企业如何列支个人收入
  • 增值税转型的主要内容
  • 非货币性资产含义
  • 逾期认证未抵扣的文件
  • 购买未完工的厂房会计分录
  • 广告制作选哪个专业好
  • 有限责任公司(自然人投资或控股)属于什么经济类型
  • 发改委规定电网企业职工福利费
  • 应收票据背书转让名词解释
  • 简易计税方法的适用范围
  • 个人独资企业办收款码
  • 商品和安装能开什么发票
  • 信息化投入包括什么投入和什么投入
  • 腾讯手游助手如何退出登录
  • ghost还原问题1823
  • linux监控系统命令
  • 总公司人员的工资子公司发,如何报税?
  • mssvr.exe - mssvr是什么进程 什么用
  • 其他应收款年末怎么处理
  • php目录结构
  • php fgets
  • 库存盘点差异会计分录
  • php 强类型
  • laravel实战教程
  • yii框架教程
  • 基于什么意思
  • php读取文件内容
  • yolov5 output
  • 开具销项负数发票 矿产品什么意思
  • 取得抵债资产支付的税费一般不包括下列哪种
  • 银行存款利息的会计科目
  • 完美解决怠速抖动加油就平稳
  • mysql零基础入门教程完整
  • 个人所得税分摊方式怎么填
  • mysql密码忘了
  • 影响留存收益变动的选折题
  • 股东滥用股东权利
  • 百旺金赋抄报税指南
  • 汇算清缴银行手续费扣除比例是多少
  • 主营业务收入借贷方
  • 小规模差额征税的账务处理
  • 应收在借方什么意思
  • 公司买车抵税最新政策2022购置税减半享受不?
  • 城市基础设施配套费征收管理规定
  • 原始凭证审核要点包括
  • 预收款开发票,不确认收入可以吗?
  • 办理食品经营许可证需要什么条件
  • 施工一个月多少钱
  • 残疾人就业保障金是什么意思啊
  • 公司为员工购买小汽车属于什么所得
  • 企业所得税费用标准
  • 安全费用支付
  • 对于审核后的凭证可直接修改对吗
  • 对公受托理财申购怎么写
  • sum(case when then)(判断男女生的个数)
  • 获取sqlsession
  • Mysql使用or如何优化
  • 不能用鼠标
  • mac进去不了系统
  • win7本地磁盘图标变了
  • win8怎么查看隐藏文件
  • 怎么做win8系统
  • 为了保证系统安全,必须为用户和角色设置密码
  • cocos2dx 3.4 lua加密 setXXTEAKeyAndSign
  • cocos2dx-js
  • ExtJS 2.0实用简明教程之应用ExtJS
  • 一个简单的灵魂
  • 基于像素的分类方法
  • c#中抽象类的定义
  • javascript教程推荐知乎
  • websocket方法
  • 福建税务局网上办税
  • 福利企业免税有哪些项目
  • 国家税务总局服务平台
  • 劳动仲裁受理通知
  • 税务局的纳税服务中心是干什么的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设