files/en-us/mozilla/add-ons/webextensions/api/webnavigation/getframe/index.md
Retrieves information about a particular frame. A frame may be the top-level frame in a tab or a nested <iframe>, and is uniquely identified by a tab ID and a frame ID.
This is an asynchronous function that returns a Promise.
let gettingFrame = browser.webNavigation.getFrame(
details // object
)
details
object. Information about the frame to retrieve information about. Must include one of tabId, frameId, or documentId.
tabId {{optional_inline}}
integer. The ID of the tab in which the frame is.processId {{optional_inline}} {{deprecated_inline}}
integer. This value is not set in modern browsers. When it was set, it represented the ID of the process running the renderer for this tab.frameId {{optional_inline}}
integer. The ID of the frame in the given tab.documentId {{optional_inline}}
string. The UUID of the frame's document.Must include one of
A Promise that is fulfilled with an object containing these properties:
errorOccurred
boolean. True if the last navigation in this frame was interrupted by an error, i.e., the {{WebExtAPIRef("webNavigation.onErrorOccurred", "onErrorOccurred")}} event fired.url
string. The URL associated with this frame, if the frame identified by frameId existed at one point in the tab identified by tabId. The fact that a URL is associated with a given frameId does not imply that the corresponding frame still exists.frameType
string. The type of frame. Returns the values "outermost_frame", "fenced_frame", or "sub_frame" .parentFrameId
integer. ID of this frame's parent. This is -1 if there is no parent frame: that is, if this frame is the top-level browsing context in the tab.documentId
string. A UUID of the frame's document.parentDocumentId
string. A UUID of the parent document owning the frame. Not set if there is no parent.documentLifecycle
string. The lifecycle the document is in. Returns the values "prerender", "active", "cached", or "pending_deletion".If the tab is discarded, the promise will instead resolve with a null value. If the specified tab or frame ID could not be found, or some other error occurs, the promise will be rejected with an error message.
function onGot(frameInfo) {
console.log(frameInfo);
}
function onError(error) {
console.log(`Error: ${error}`);
}
let gettingFrame = browser.webNavigation.getFrame({
tabId: 19,
frameId: 1537,
});
// Edge specific - processId is required not optional, must be integer not null
// let gettingFrame = browser.webNavigation.getFrame({ tabId: 19, processId: 0, frameId: 1537 });
gettingFrame.then(onGot, onError);
{{WebExtExamples}}
{{Compat}}
<!-- // Copyright 2015 The Chromium Authors. All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are // met: // // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above // copyright notice, this list of conditions and the following disclaimer // in the documentation and/or other materials provided with the // distribution. // * Neither the name of Google Inc. nor the names of its // contributors may be used to endorse or promote products derived from // this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -->[!NOTE] This API is based on Chromium's
chrome.webNavigationAPI. This documentation is derived fromweb_navigation.jsonin the Chromium code.