-
Notifications
You must be signed in to change notification settings - Fork 312
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to properly handle iframe "swaps" (FrameDetached, Reason "swap")? #558
Comments
Running Chrome with |
I already can see that. The whole topic has already been discussed and my “feeling” has somehow been confirmed. It's probably about “OOPIFs” and that makes the story quite complex. Has anyone perhaps already realized this with |
Well, the protocol is the same, so whatever works in Puppeteer, should work here too. The protocol however is complex, mostly experimental, and I have nothing to do with that. Whenever I face similar issues I just read the terrible documentation available and I proceed by trials and errors. Having said that, it's not clear to me what your problem is... You can register for events and react the way you want. You can |
My issue is/was, that Chrome is going to isolate iframes for different origins. So they're getting detached ("swap"), but before a new target is getting created (with the same ID). So, instead of being a part of a website, it'll get it's own target. I simply created a Map<frameId, cdpClient>() and I'm listening on targetCreated and frameDetached events. Once a target is created and a frame is detached (reason: swap) with the same ID, I create a new connection with CDP to that target and I update the cdpClient in the Map. It's pretty ugly and I don't like it. I was digging into Puppeteer and Playwright to see how they've managed it and it's almost the same. There is a Chromium flag to disable this kind of isolation, but that's ugly, too. :D |
Environment
Is the client running in a container? NO
Description
I am trying to read all frames via
Page.getFrameTree()
. It works at the start. The frames are all visible. But after a short moment aFrameDetached, Reason: swap
-event is fired.Now the question is, how to “handle” this correctly?
http://127.0.0.1:9222/json/list
shows the correct IFrames. However,Page.getFrameTree()
does not - although I would expect it to.Unfortunately, this topic has not (yet) been dealt with here. Puppeteer seems to have found a way to do this, but I couldn't find the right place in the code base. Probably because Puppeteer pays attention to
Target.targetCreated
at the same time?It also feels as if the IFrame is a “separate process”. If I connect directly via
CDP({ target: webSocketDebuggerUrl })
(while webSocketDebuggerUrl is the url to the IFrame;parentId
is the page which contains that IFrame), then it works.Example
The text was updated successfully, but these errors were encountered: