上一主题 下一主题
ScriptCat,新一代的脚本管理器脚本站,与全世界分享你的用户脚本油猴脚本开发指南教程目录
12下一页
返回列表 发新帖

[油猴脚本开发指南]操作本地文件

[复制链接]
  • TA的每日心情
    开心
    2024-3-13 10:14
  • 签到天数: 211 天

    [LV.7]常住居民III

    295

    主题

    3915

    回帖

    3835

    积分

    管理员

    积分
    3835

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-9-15 11:28:17 | 显示全部楼层 | 阅读模式
    安装此脚本 如何安装? 脚本问题反馈 给脚本评分 查看代码

    经常看见有人提问怎么去下载文件、保存文件之类的问题的,一直是说用File System Access API 但是怎么用,从没说过,今天来研究一下,顺便写一些示例

    使用之前,先注意一下浏览器兼容性Firefox是完全不支持,另外依旧有一些局限性,需要用户手动触发操作

    获取权限

    window.showOpenFilePicker/showDirectoryPicker
    这两个API用于打开一个窗口,授权文件/目录,例如下面这样

        async function getFile() {
            // open directory picker
            const dirHandle = await window.showDirectoryPicker();
            console.log(dirHandle);
        }
        getFile();

    调用后会打开一个窗口,选择允许查看的文件目录~~~~
    image.png
    确认授权
    image.png
    完成后会返回一个下面这样的结构体
    image.png

    但是刷新页面后,会报下面这个错误,必须要有用户操作触发才行(但是不知道为什么第一次是可以的。。。)

    Failed to execute 'showDirectoryPicker' on 'Window': Must be handling a user gesture to show a file picker.

    像这样,在这里我指定来一个参数{mode:"readwrite"},这样就可以获取目录的读写权限,对目录为所欲为

        const button = document.createElement('button');
        button.innerText = "点我授权目录";
        document.body.firstChild.after(button);
        button.addEventListener('click', async function () {
            async function getFile() {
                // open directory picker
                const dirHandle = await window.showDirectoryPicker({mode:"readwrite"});
                console.log(dirHandle);
            }
            getFile();
        });

    另外我发现返回的dirHandle的对象是可以存到indexedDB(可以存储js 对象)中去的,但是不清楚能不能继续给下次调用,有兴趣的朋友可以试试。

    读写文件

    既然获取到了权限,就来试试能不能操作本地文件,获取到的对象是:FileSystemDirectoryHandle,更多内容可看MDN

     const button2 = document.createElement('button');
        button2.innerText = "点我读取目录&写点东西";
        document.body.firstChild.after(button2);
        button2.addEventListener('click', async function () {
            // 读取目录
            for await (const item of dirHandle.values()) {
                console.log(item)
            }
            // 写文件
            const fileHandle = await dirHandle.getFileHandle("hello-world.txt", { create: true });
            const writable = await fileHandle.createWritable();
            await writable.write("Hello World!");
            await writable.close();
        });

    END

    简单过了一下FileSystemAPI,感觉还是很强大的,应该能衍生不少玩法

    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。/ 微信公众号:一之哥哥
  • TA的每日心情
    慵懒
    6 小时前
  • 签到天数: 638 天

    [LV.9]以坛为家II

    30

    主题

    536

    回帖

    1411

    积分

    荣誉开发者

    积分
    1411

    荣誉开发者新人进步奖油中2周年生态建设者新人报道挑战者 lv2油中3周年喜迎中秋

    发表于 2022-9-15 12:23:44 | 显示全部楼层
    GGNB,试了下只有脚本猫能用?油猴似乎不能用【脚本猫NB
    另外建议把自动调用的getFile()删了,好像是这行出了问题,可能一定要用户真实操作才能正常用(类似isTrusted)?

    点评

    原来是没声明// @grant none导致油猴不能正常用0.0  发表于 2022-9-15 13:30
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-4-14 00:00
  • 签到天数: 119 天

    [LV.6]常住居民II

    29

    主题

    599

    回帖

    536

    积分

    专家

    积分
    536

    油中2周年生态建设者油中3周年挑战者 lv2

    发表于 2022-9-15 13:13:48 | 显示全部楼层
    油猴中文网确实能学到不少东西。。。
    然脚本猫一定要去兼容别的脚本管理器?我倒是希望脚本猫出几个炸天的特性。你还只能在脚本猫上使,那就好气人了
    入驻爱发电 让这世界充满爱 https://afdian.net/a/vpannice
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-4-14 00:00
  • 签到天数: 119 天

    [LV.6]常住居民II

    29

    主题

    599

    回帖

    536

    积分

    专家

    积分
    536

    油中2周年生态建设者油中3周年挑战者 lv2

    发表于 2022-9-15 13:29:49 | 显示全部楼层
    另外我发现返回的dirHandle的对象是可以存到indexedDB(可以存储js 对象)中去的,但是不清楚能不能继续给下次调用,有兴趣的朋友可以试试。
    你在暗示什么?
    入驻爱发电 让这世界充满爱 https://afdian.net/a/vpannice
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-3-13 10:14
  • 签到天数: 211 天

    [LV.7]常住居民III

    295

    主题

    3915

    回帖

    3835

    积分

    管理员

    积分
    3835

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-9-15 13:45:40 | 显示全部楼层
    脚本体验师001 发表于 2022-9-15 13:13
    油猴中文网确实能学到不少东西。。。
    然脚本猫一定要去兼容别的脚本管理器?我倒是希望脚本猫出几个炸天的 ...

    有点想不到有什么好特性能出了
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。/ 微信公众号:一之哥哥
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-3-13 10:14
  • 签到天数: 211 天

    [LV.7]常住居民III

    295

    主题

    3915

    回帖

    3835

    积分

    管理员

    积分
    3835

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-9-15 13:46:57 | 显示全部楼层
    脚本体验师001 发表于 2022-9-15 13:29
    另外我发现返回的dirHandle的对象是可以存到indexedDB(可以存储js 对象)中去的,但是不清楚能不能继续给 ...

    我看vscode web实现的时候 无意间看到这个对象存进了indexeddb,不知道是有什么作用没。可能只是做个记录 用来读取之前打开过的文件夹而已
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。/ 微信公众号:一之哥哥
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-3-13 10:14
  • 签到天数: 211 天

    [LV.7]常住居民III

    295

    主题

    3915

    回帖

    3835

    积分

    管理员

    积分
    3835

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-9-15 13:47:33 | 显示全部楼层
    steven026 发表于 2022-9-15 12:23
    GGNB,试了下只有脚本猫能用?油猴似乎不能用【脚本猫NB
    另外建议把自动调用的getFile()删了,好像是这行出 ...

    这我没注意 我用脚本猫的。应该和实现有关,油猴试试unsafe Window
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。/ 微信公众号:一之哥哥
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2024-3-13 10:14
  • 签到天数: 211 天

    [LV.7]常住居民III

    295

    主题

    3915

    回帖

    3835

    积分

    管理员

    积分
    3835

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-9-15 13:48:17 | 显示全部楼层
    steven026 发表于 2022-9-15 12:23
    GGNB,试了下只有脚本猫能用?油猴似乎不能用【脚本猫NB
    另外建议把自动调用的getFile()删了,好像是这行出 ...

    第一次调用时getFile有用。。。
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。/ 微信公众号:一之哥哥
    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    6 小时前
  • 签到天数: 638 天

    [LV.9]以坛为家II

    30

    主题

    536

    回帖

    1411

    积分

    荣誉开发者

    积分
    1411

    荣誉开发者新人进步奖油中2周年生态建设者新人报道挑战者 lv2油中3周年喜迎中秋

    发表于 2022-9-15 13:56:25 | 显示全部楼层
    王一之 发表于 2022-9-15 13:47
    这我没注意 我用脚本猫的。应该和实现有关,油猴试试unsafe Window

    油猴好像不声明//@grant none就默认是沙盒环境
    然后document可能就指向沙盒环境的window上去了
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    昨天 13:52
  • 签到天数: 591 天

    [LV.9]以坛为家II

    43

    主题

    184

    回帖

    703

    积分

    荣誉开发者

    积分
    703

    荣誉开发者油中2周年生态建设者

    发表于 2022-9-15 16:01:57 | 显示全部楼层
    我敲,好东西,以前安卓autojs与浏览器通信我用的将信息写在网页上,让autojs去读取,然后浏览器读取本地文件使用的require js(用autojs写的js文件)
    回复

    使用道具 举报

    发表回复

    本版积分规则

    快速回复 返回顶部 返回列表