# webFrameMain > Control web pages and iframes. Process: [Main](../glossary.md#main-process) The `webFrameMain` module can be used to lookup frames across existing [`WebContents`](web-contents.md) instances. Navigation events are the common use case. ```javascript const { BrowserWindow, webFrameMain } = require('electron') const win = new BrowserWindow({ width: 800, height: 1500 }) win.loadURL('https://twitter.com') win.webContents.on( 'did-frame-navigate', (event, url, isMainFrame, frameProcessId, frameRoutingId) => { const frame = webFrameMain.fromId(frameProcessId, frameRoutingId) if (frame) { const code = 'document.body.innerHTML = document.body.innerHTML.replaceAll("heck", "h*ck")' frame.executeJavaScript(code) } } ) ``` You can also access frames of existing pages by using the `webFrame` property of [`WebContents`](web-contents.md). ```javascript const { BrowserWindow } = require('electron') async function main () { const win = new BrowserWindow({ width: 800, height: 600 }) await win.loadURL('https://reddit.com') const youtubeEmbeds = win.webContents.mainFrame.frames.filter((frame) => { try { const url = new URL(frame.url) return url.host === 'www.youtube.com' } catch { return false } }) console.log(youtubeEmbeds) } main() ``` ## Methods These methods can be accessed from the `webFrameMain` module: ### `webFrameMain.fromId(processId, routingId)` * `processId` Integer - An `Integer` representing the id of the process which owns the frame. * `routingId` Integer - An `Integer` representing the unique frame id in the current renderer process. Routing IDs can be retrieved from `WebFrameMain` instances (`frame.routingId`) and are also passed by frame specific `WebContents` navigation events (e.g. `did-frame-navigate`). Returns `WebFrameMain` - A frame with the given process and routing IDs. ## Class: WebFrameMain Process: [Main](../glossary.md#main-process) ### Instance Methods #### `frame.executeJavaScript(code[, userGesture])` * `code` String * `userGesture` Boolean (optional) - Default is `false`. Returns `Promise` - A promise that resolves with the result of the executed code or is rejected if execution throws or results in a rejected promise. Evaluates `code` in page. In the browser window some HTML APIs like `requestFullScreen` can only be invoked by a gesture from the user. Setting `userGesture` to `true` will remove this limitation. #### `frame.reload()` Returns `boolean` - Whether the reload was initiated successfully. Only results in `false` when the frame has no history. ### Instance Properties #### `frame.url` _Readonly_ A `string` representing the current URL of the frame. #### `frame.top` _Readonly_ A `WebFrameMain | null` representing top frame in the frame hierarchy to which `frame` belongs. #### `frame.parent` _Readonly_ A `WebFrameMain | null` representing parent frame of `frame`, the property would be `null` if `frame` is the top frame in the frame hierarchy. #### `frame.frames` _Readonly_ A `WebFrameMain[]` collection containing the direct descendents of `frame`. #### `frame.framesInSubtree` _Readonly_ A `WebFrameMain[]` collection containing every frame in the subtree of `frame`, including itself. This can be useful when traversing through all frames. #### `frame.frameTreeNodeId` _Readonly_ An `Integer` representing the id of the frame's internal FrameTreeNode instance. This id is browser-global and uniquely identifies a frame that hosts content. The identifier is fixed at the creation of the frame and stays constant for the lifetime of the frame. When the frame is removed, the id is not used again. #### `frame.processId` _Readonly_ An `Integer` representing the id of the process which owns this frame. #### `frame.routingId` _Readonly_ An `Integer` representing the unique frame id in the current renderer process. Distinct `WebFrameMain` instances that refer to the same underlying frame will have the same `routingId`.