tauri2前端获取应用配置目录并创建文件和目录

获取平台信息

js 复制代码
// platform值为:windows
import { platform } from '@tauri-apps/plugin-os';

选择系统文件夹并获取路径

js 复制代码
import { open, save } from '@tauri-apps/plugin-dialog';
const selectedPath = await open({
    multiple: false,
    directory: true,
    title: "请选择游戏里的Mods安装目录",
});

// selectedPath为打开的路径
if (selectedPath) {
}

获取应用的配置目录

js 复制代码
import { appConfigDir, appDataDir, homeDir, join } from '@tauri-apps/api/path';
const appConfigDirPath = await appConfigDir();
// appConfigDir: C:\Users\yaya\AppData\Roaming\com.luckyriko.hellrat
console.log('appConfigDir:', appConfigDirPath);

const appDataDirPath = await appDataDir();
// appDataDir: C:\Users\yaya\AppData\Roaming\com.luckyriko.hellrat
console.log('appDataDir:', appDataDirPath);

const homeDirPath = await homeDir();
// homeDir: C:\Users\yaya
console.log('homeDir:', homeDirPath);

在应用的配置目录下创建文件和目录

js 复制代码
import { exists, mkdir, create, readTextFile, writeTextFile, BaseDirectory } from '@tauri-apps/plugin-fs';

try {
    // 创建文件:不存在配置文件则去创建,并写入json格式的内容
    const flag = await exists('config.json', { baseDir: BaseDirectory.AppConfig });
    if (!flag) {
        const file = await create('config.json', { baseDir: BaseDirectory.AppData });
        await file.write(new TextEncoder().encode(JSON.stringify({ aaa: '', bbb: '' })));
        await file.close();
    }

    // 读取json内容
    const contents = await readTextFile('config.json', {
      baseDir: BaseDirectory.AppConfig,
    });
    if (contents) {
      const config = JSON.parse(contents);
    }

    // 创建目录:不存在mod目录则去创建
    // 使用join拼接目录可以无视平台差异
    const appConfigDirPath = await appConfigDir();
    let modsDir = await join(appConfigDirPath, 'mods');

    const modsDirExists = await exists('mods', {
        baseDir: BaseDirectory.AppConfig,
    });
    if (!modsDirExists) {
        await mkdir('mods', { baseDir: BaseDirectory.AppConfig })
    }
} catch (error) {
    console.error('打印错误:', error);

} 

其实还有一种更简单的方法,使用官方插件可以更便捷的创建配置文件和目录 v2.tauri.app/plugin/stor...

相关推荐
你的人类朋友1 分钟前
什么是断言?
前端·后端·安全
FIN66681 小时前
昂瑞微:实现精准突破,攻坚射频“卡脖子”难题
前端·人工智能·安全·前端框架·信息与通信
椎4951 小时前
苍穹外卖前端nginx错误之一解决
运维·前端·nginx
@。1241 小时前
对于灰度发布(金丝雀发布)的了解
开发语言·前端
我有一棵树1 小时前
前端图片加载失败、 img 出现裂图的原因全解析
前端
FIN66681 小时前
昂瑞微冲刺科创板:硬科技与资本市场的双向奔赴
前端·人工智能·科技·前端框架·智能
im_AMBER1 小时前
杂记 14
前端·笔记·学习·web
牧杉-惊蛰1 小时前
disable-devtool 网络安全 禁止打开控制台
前端·css·vue.js
C+ 安口木2 小时前
vue中监听window某个属性被添加或值的变化
前端·javascript·vue.js
山海鲸可视化2 小时前
简单聊聊数据可视化大屏制作的前端设计与后端开发
前端·信息可视化·数字孪生·数据可视化·3d模型·三维渲染