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

关于iframe问题的求助

[复制链接]
  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2023-12-23 00:08:54 | 显示全部楼层 | 阅读模式

    求助各位大佬,我遇到的需求场景是:我通过油猴脚本在当前页面注入了一个iframe元素,顺利打开了src的链接,然后——
    我需要在判断这个iframe元素完全加载之后,自动把这个iframe元素删掉,再加载下一个我设定的iframe元素
    请问是否可以实现?

  • TA的每日心情
    开心
    2023-2-28 23:59
  • 签到天数: 191 天

    [LV.7]常住居民III

    637

    主题

    5202

    回帖

    6082

    积分

    管理员

    非物质文化遗产社会摇传承人

    积分
    6082

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

    发表于 2023-12-23 05:27:18 | 显示全部楼层
    可以主页面监听事件
    iframe触发某些特定事件互相沟通
    混的人。
    ------------------------------------------
    進撃!永遠の帝国の破壊虎---李恒道

    入驻了爱发电https://afdian.net/a/lihengdao666
    个人宣言:この世界で私に胜てる人とコードはまだ生まれていません。死ぬのが怖くなければ来てください。
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2024-1-7 00:42:16 | 显示全部楼层
    李恒道 发表于 2023-12-23 05:27
    可以主页面监听事件
    iframe触发某些特定事件互相沟通

    哥哥我要付费求教学太难了这个
    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    2022-3-8 11:41
  • 签到天数: 2 天

    [LV.1]初来乍到

    22

    主题

    862

    回帖

    1361

    积分

    荣誉开发者

    积分
    1361

    荣誉开发者卓越贡献油中2周年生态建设者油中3周年挑战者 lv2

    发表于 2024-1-8 22:24:07 | 显示全部楼层
    1. function waitAndRemove(iframe) {
    2.     return new Promise(resolve => {
    3.         iframe.addEventListener('load', e => {
    4.             iframe.remove();
    5.             resolve();
    6.         });
    7.     });
    8. }

    9. (async function() {
    10.     const iframe1 = createIframe();
    11.     await waitAndRemove(iframe1);
    12.     const iframe2 = createIframe();
    13.     await waitAndRemove(iframe2);
    14. })();
    复制代码
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2024-1-9 12:46:31 | 显示全部楼层

    谢谢 cxxjackie 大佬指点!
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2024-1-23 00:02:03 | 显示全部楼层

    本帖最后由 xiaooooooo 于 2024-1-23 00:04 编辑

    感谢大佬指点。我在您的代码结合我的需求做了一点改动,原因在于如果以'load'事件来作为关闭iframe的时机的话,会导致我在iframe页面上注入的代码还没有来得及执行完毕,这个iframe就被关闭了。

    因此我试着参照李恒道大佬的postMessage方法进行改造,参考链接

    在主页面增加以下代码:

    function waitAndRemove(iframe) {
        return new Promise(resolve => {
    
            const ListenMessage= (e)=> {
                if(e.data==='close_window'){
                    iframe.removeEventListener('message', ListenMessage)
                    //关闭窗口代码
                    iframe.remove();
                    resolve()
                }
            };
            iframe.addEventListener('message', ListenMessage);
    
        });
    }
    
    。。。。。。
    (async function() {
                await waitAndRemove(iframe);
            })();
    。。。。。。

    在子页面(iframe)打开的页面注入如下代码:

    function EmitParentClose(){
        let parentif = window.top;
        parentif.postMessage('close_window')
    }
    
    。。。。。。
    
            // 发送关闭信号
            EmitParentClose();
    。。。。。。

    但是并未奏效,不知原因何在。另外我也想请教一下,这个postMessage发送回来的这个消息,是应当打印在dev tools的console里面吗?

    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    2022-3-8 11:41
  • 签到天数: 2 天

    [LV.1]初来乍到

    22

    主题

    862

    回帖

    1361

    积分

    荣誉开发者

    积分
    1361

    荣誉开发者卓越贡献油中2周年生态建设者油中3周年挑战者 lv2

    发表于 2024-1-23 22:12:50 | 显示全部楼层
    xiaooooooo 发表于 2024-1-23 00:02
    [md]感谢大佬指点。我在您的代码结合我的需求做了一点改动,原因在于如果以'load'事件来作为关闭iframe的时 ...

    在iframe内window.top指的是主页面,因此你的消息是直接发送到主页面的,在主页面中应对window做监听而非iframe,参考:https://bbs.tampermonkey.net.cn/thread-2895-1-1.html
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2024-1-24 00:42:46 | 显示全部楼层

    cxxjackie 发表于 2024-1-23 22:12

    在iframe内window.top指的是主页面,因此你的消息是直接发送到主页面的,在主页面中应对window做监听而非 ...

    感谢大佬指点。现在我在代码上做了如下修改

    在主页面油猴脚本代码:

    function waitAndRemove(iframe) {
        return new Promise(resolve => {
    
            const ListenMessage= (e)=> {
                if(e.data==='close_window'){
                    window.removeEventListener('message', ListenMessage)
                    //关闭窗口代码
                    iframe.remove();
                    resolve()
                }
            };
            window.addEventListener('message', ListenMessage);
    
        });
    }
    
    。。。。。。
    (async function() {
                await waitAndRemove(iframe);
            })();
    。。。。。。

    在子页面(iframe)打开的页面注入如下代码:

    function EmitParentClose(){
        let parentif = window.top;
        parentif.postMessage('close_window','*')
    }
    
    。。。。。。
    
            // 发送关闭信号
            EmitParentClose();
    。。。。。。

    主页面成功接收到了'close_window'信号并删除了iframe元素。但有一个新的问题,我在主页面创建了20个iframe,但是只收到了6个iframe页面的内容。也就是说,我猜想由于我的iframe元素不能编号区分,导致在remove的时候,同时关闭了所有iframe,造成信息丢失。请问我该如何实现【依次关闭】?

    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-2-28 23:59
  • 签到天数: 191 天

    [LV.7]常住居民III

    637

    主题

    5202

    回帖

    6082

    积分

    管理员

    非物质文化遗产社会摇传承人

    积分
    6082

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

    发表于 2024-1-24 07:18:17 | 显示全部楼层
    xiaooooooo 发表于 2024-1-24 00:42
    [md]感谢大佬指点。现在我在代码上做了如下修改

    在主页面油猴脚本代码:

    这要看你具体实现了
    比如你可以主页面给子页面一个唯一uuid并且标识iframe
    子页面发送关闭主页面控制关闭
    混的人。
    ------------------------------------------
    進撃!永遠の帝国の破壊虎---李恒道

    入驻了爱发电https://afdian.net/a/lihengdao666
    个人宣言:この世界で私に胜てる人とコードはまだ生まれていません。死ぬのが怖くなければ来てください。
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2023-7-13 09:56
  • 签到天数: 2 天

    [LV.1]初来乍到

    9

    主题

    93

    回帖

    119

    积分

    中级工程师

    积分
    119

    油中2周年油中3周年

    发表于 2024-1-24 10:58:12 | 显示全部楼层
    李恒道 发表于 2024-1-24 07:18
    这要看你具体实现了
    比如你可以主页面给子页面一个唯一uuid并且标识iframe
    子页面发送关闭主页面控制关闭 ...

    有点设计不出来这个机制。比如我在生成iframe的时候带上一个id属性,但是有个问题在关闭窗口代码当中, iframe.remove()怎么加这个判断id的语句呢?
    回复

    使用道具 举报

    发表回复

    本版积分规则

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