Use the webview
tag to embed 'guest' content (such as web pages) in your
Electron app. The guest content is contained within the webview
container.
An embedded page within your app controls how the guest content is laid out and
rendered.
Unlike an iframe
, the webview
runs in a separate process than your
app. It doesn't have the same permissions as your web page and all interactions
between your app and embedded content will be asynchronous. This keeps your app
safe from the embedded content.
To embed a web page in your app, add the webview
tag to your app's embedder
page (this is the app page that will display the guest content). In its simplest
form, the webview
tag includes the src
of the web page and css styles that
control the appearance of the webview
container:
<webview id="foo" src="https://www.github.com/" style="display:inline-block; width:640px; height:480px"></webview>
If you want to control the guest content in any way, you can write JavaScript
that listens for webview
events and responds to those events using the
webview
methods. Here's sample code with two event listeners: one that listens
for the web page to start loading, the other for the web page to stop loading,
and displays a "loading..." message during the load time:
<script>
onload = function() {
var webview = document.getElementById("foo");
var indicator = document.querySelector(".indicator");
var loadstart = function() {
indicator.innerText = "loading...";
}
var loadstop = function() {
indicator.innerText = "";
}
webview.addEventListener("did-start-loading", loadstart);
webview.addEventListener("did-stop-loading", loadstop);
}
</script>
The webview
tag has the following attributes:
<webview src="https://www.github.com/"></webview>
Returns the visible URL. Writing to this attribute initiates top-level navigation.
Assigning src
its own value will reload the current page.
The src
attribute can also accept data URLs, such as
data:text/plain,Hello, world!
.
<webview src="https://www.github.com/" autosize="on" minwidth="576" minheight="432"></webview>
If "on", the webview
container will automatically resize within the
bounds specified by the attributes minwidth
, minheight
, maxwidth
, and
maxheight
. These constraints do not impact the webview
unless autosize
is
enabled. When autosize
is enabled, the webview
container size cannot be less
than the minimum values or greater than the maximum.
<webview src="http://www.google.com/" nodeintegration></webview>
If "on", the guest page in webview
will have node integration and can use node
APIs like require
and process
to access low level system resources.
<webview src="https://www.github.com/" plugins></webview>
If "on", the guest page in webview
will be able to use browser plugins.
<webview src="https://www.github.com/" preload="./test.js"></webview>
Specifies a script that will be loaded before other scripts run in the guest
page. The protocol of script's URL must be either file:
or asar:
, because it
will be loaded by require
in guest page under the hood.
When the guest page doesn't have node integration this script will still have access to all Node APIs, but global objects injected by Node will be deleted after this script has finished executing.
<webview src="https://www.github.com/" httpreferrer="http://cheng.guru"></webview>
Sets the referrer URL for the guest page.
<webview src="https://www.github.com/" useragent="Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; AS; rv:11.0) like Gecko"></webview>
Sets the user agent for the guest page before the page is navigated to. Once the
page is loaded, use the setUserAgent
method to change the user agent.
<webview src="https://www.github.com/" disablewebsecurity></webview>
If "on", the guest page will have web security disabled.
<webview src="https://github.com" partition="persist:github"></webview>
<webview src="http://electron.atom.io" partition="electron"></webview>
Sets the session used by the page. If partition
starts with persist:
, the
page will use a persistent session available to all pages in the app with the
same partition
. if there is no persist:
prefix, the page will use an
in-memory session. By assigning the same partition
, multiple pages can share
the same session. If the partition
is unset then default session of the app
will be used.
This value can only be modified before the first navigation, since the session of an active renderer process cannot change. Subsequent attempts to modify the value will fail with a DOM exception.
<webview src="https://www.github.com/" allowpopups></webview>
If "on", the guest page will be allowed to open new windows.
The webview
tag has the following methods:
Note: The webview element must be loaded before using the methods.
Example
webview.addEventListener("dom-ready", function() {
webview.openDevTools();
});
Returns URL of guest page.
Returns the title of guest page.
Returns a boolean whether guest page is still loading resources.
Returns a boolean whether the guest page is waiting for a first-response for the main resource of the page.
Stops any pending navigation.
Reloads the guest page.
Reloads the guest page and ignores cache.
Returns a boolean whether the guest page can go back.
Returns a boolean whether the guest page can go forward.
offset
Integer
Returns a boolean whether the guest page can go to offset
.
Clears the navigation history.
Makes the guest page go back.
Makes the guest page go forward.
index
Integer
Navigates to the specified absolute index.
offset
Integer
Navigates to the specified offset from the "current entry".
Whether the renderer process has crashed.
userAgent
String
Overrides the user agent for the guest page.
Returns a String
representing the user agent for guest page.
css
String
Injects CSS into the guest page.
code
StringuserGesture
Boolean - Defaultfalse
.
Evaluates code
in page. If userGesture
is set, it will the create user
gesture context in the page. HTML APIs like requestFullScreen
, which require
user action, can take advantage of this option for automation.
Opens a DevTools window for guest page.
Closes the DevTools window of guest page.
Returns a boolean whether guest page has a DevTools window attached.
x
Integery
Integer
Starts inspecting element at position (x
, y
) of guest page.
Opens the DevTools for the service worker context present in the guest page.
muted
Boolean
Set guest page muted.
Returns whether guest page has been muted.
Executes editing command undo
in page.
Executes editing command redo
in page.
Executes editing command cut
in page.
Executes editing command copy
in page.
Executes editing command paste
in page.
Executes editing command pasteAndMatchStyle
in page.
Executes editing command delete
in page.
Executes editing command selectAll
in page.
Executes editing command unselect
in page.
text
String
Executes editing command replace
in page.
text
String
Executes editing command replaceMisspelling
in page.
Prints webview
's web page. Same with webContents.print([options])
.
Prints webview's web page as PDF, Same with webContents.printToPDF(options, callback)
channel
Stringarg
(optional)
Send args..
to guest page via channel
in asynchronous message, the guest
page can handle it by listening to the channel
event of ipc
module.
See WebContents.send for examples.
event
Object
Sends an input event
to the page.
See WebContents.sendInputEvent
for detailed description of event
object.
The following DOM events are available to the webview
tag:
Returns:
url
StringisMainFrame
Boolean
Fired when a load has committed. This includes navigation within the current document as well as subframe document-level loads, but does not include asynchronous resource loads.
Fired when the navigation is done, i.e. the spinner of the tab will stop
spinning, and the onload
event is dispatched.
Returns:
errorCode
IntegererrorDescription
StringvalidatedUrl
String
This event is like did-finish-load
, but fired when the load failed or was
cancelled, e.g. window.stop()
is invoked.
Returns:
isMainFrame
Boolean
Fired when a frame has done navigation.
Corresponds to the points in time when the spinner of the tab starts spinning.
Corresponds to the points in time when the spinner of the tab stops spinning.
Returns:
status
BooleannewUrl
StringoriginalUrl
StringhttpResponseCode
IntegerrequestMethod
Stringreferrer
Stringheaders
Object
Fired when details regarding a requested resource is available.
status
indicates socket connection to download the resource.
Returns:
oldUrl
StringnewUrl
StringisMainFrame
Boolean
Fired when a redirect was received while requesting a resource.
Fired when document in the given frame is loaded.
Returns:
title
StringexplicitSet
Boolean
Fired when page title is set during navigation. explicitSet
is false when title is synthesised from file
url.
Returns:
favicons
Array - Array of Urls.
Fired when page receives favicon urls.
Fired when page enters fullscreen triggered by HTML API.
Fired when page leaves fullscreen triggered by HTML API.
Returns:
level
Integermessage
Stringline
IntegersourceId
String
Fired when the guest window logs a console message.
The following example code forwards all log messages to the embedder's console without regard for log level or other properties.
webview.addEventListener('console-message', function(e) {
console.log('Guest page logged a message:', e.message);
});
Returns:
url
StringframeName
Stringdisposition
String - Can bedefault
,foreground-tab
,background-tab
,new-window
andother
.options
Object - The options which should be used for creating the newBrowserWindow
.
Fired when the guest page attempts to open a new browser window.
The following example code opens the new url in system's default browser.
webview.addEventListener('new-window', function(e) {
require('shell').openExternal(e.url);
});
Fired when the guest page attempts to close itself.
The following example code navigates the webview
to about:blank
when the
guest attempts to close itself.
webview.addEventListener('close', function() {
webview.src = 'about:blank';
});
Returns:
channel
Stringargs
Array
Fired when the guest page has sent an asynchronous message to embedder page.
With sendToHost
method and ipc-message
event you can easily communicate
between guest page and embedder page:
// In embedder page.
webview.addEventListener('ipc-message', function(event) {
console.log(event.channel);
// Prints "pong"
});
webview.send('ping');
// In guest page.
var ipc = require('ipc');
ipc.on('ping', function() {
ipc.sendToHost('pong');
});
Fired when the renderer process is crashed.
Fired when the gpu process is crashed.
Returns:
name
Stringversion
String
Fired when a plugin process is crashed.
Fired when the WebContents is destroyed.