前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >tauri学习(4)-多窗口

tauri学习(4)-多窗口

作者头像
菩提树下的杨过
发布2022-08-23 16:05:59
2.8K1
发布2022-08-23 16:05:59
举报

上节继续,今天研究tauri中的多窗口,要实现多窗口有几种方式:

一、改配置tauri.conf.json

仍然以react项目模式为例,假设我们有2个页面效果:

在浏览器中运行起来长这样:

tauri中,如果想开2个窗口,分别对应于这2个页面,可以参考下图配置:

(关于windows节点下,具体有哪些属性可配置,可参考官网文档)

运行起来效果如下:

二、Rust中使用app创建窗口

代码语言:javascript
复制
use tauri::{WindowBuilder, WindowUrl};

fn main() {
  tauri::Builder::default()
    .setup(|app| {
      WindowBuilder::new(
        app,
        "external",
        WindowUrl::External("http://yjmyzz.cnblogs.com/".parse().unwrap()),
      )
      .title("菩提村下的杨过")
      .inner_size(640.0, 480.0)
      .position(50.0, 100.0)
      .build()?;
      Ok(())
    })
    .run(tauri::generate_context!())
    .expect("error while running tauri application");
}

运行起来后,加上方式1中的2个窗口,总共会有3个窗口:

三、前端创建窗口

3.1 使用tauri::command

上节学习过前端可以调用Rust中的方法,同样这种方式,也可以创建窗口。先把tauri.conf.json中的配置恢复成单窗口,方式二中创建的窗口也去掉,然后加1个可供前端调用的新方法:

然后在Home组件中,调用该方法:

运行效果:

 3.2 js API调用

运行效果:

四、运行时获取窗口引用

比如想用代码把前面创建的2个about窗口给关闭,就必须先获取窗口的引用,参考下面的代码:

运行效果:

参考文章:

https://tauri.app/v1/guides/features/multiwindow

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档