docs: use node:
imports for node core modules (#39681)
docs: use `node:` imports for node builtin modules
This commit is contained in:
parent
2182202e8e
commit
b8ac798344
23 changed files with 39 additions and 39 deletions
|
@ -78,7 +78,7 @@ binary. Use this to spawn Electron from Node scripts:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const electron = require('electron')
|
const electron = require('electron')
|
||||||
const proc = require('child_process')
|
const proc = require('node:child_process')
|
||||||
|
|
||||||
// will print something similar to /Users/maf/.../Electron
|
// will print something similar to /Users/maf/.../Electron
|
||||||
console.log(electron)
|
console.log(electron)
|
||||||
|
|
|
@ -1333,7 +1333,7 @@ application name. For example:
|
||||||
|
|
||||||
``` js
|
``` js
|
||||||
const { app } = require('electron')
|
const { app } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const appFolder = path.dirname(process.execPath)
|
const appFolder = path.dirname(process.execPath)
|
||||||
const updateExe = path.resolve(appFolder, '..', 'Update.exe')
|
const updateExe = path.resolve(appFolder, '..', 'Update.exe')
|
||||||
|
@ -1404,7 +1404,7 @@ Returns `Function` - This function **must** be called once you have finished acc
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { app, dialog } = require('electron')
|
const { app, dialog } = require('electron')
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
|
|
||||||
let filepath
|
let filepath
|
||||||
let bookmark
|
let bookmark
|
||||||
|
|
|
@ -1211,7 +1211,7 @@ const win = new BrowserWindow()
|
||||||
const url = require('url').format({
|
const url = require('url').format({
|
||||||
protocol: 'file',
|
protocol: 'file',
|
||||||
slashes: true,
|
slashes: true,
|
||||||
pathname: require('path').join(__dirname, 'index.html')
|
pathname: require('node:path').join(__dirname, 'index.html')
|
||||||
})
|
})
|
||||||
|
|
||||||
win.loadURL(url)
|
win.loadURL(url)
|
||||||
|
|
|
@ -147,7 +147,7 @@ Be very cautious about which globals and APIs you expose to untrusted remote con
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { contextBridge } = require('electron')
|
const { contextBridge } = require('electron')
|
||||||
const crypto = require('crypto')
|
const crypto = require('node:crypto')
|
||||||
contextBridge.exposeInMainWorld('nodeCrypto', {
|
contextBridge.exposeInMainWorld('nodeCrypto', {
|
||||||
sha256sum (data) {
|
sha256sum (data) {
|
||||||
const hash = crypto.createHash('sha256')
|
const hash = crypto.createHash('sha256')
|
||||||
|
|
|
@ -33,7 +33,7 @@ to register it to that session explicitly.
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { app, BrowserWindow, net, protocol, session } = require('electron')
|
const { app, BrowserWindow, net, protocol, session } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
const url = require('url')
|
const url = require('url')
|
||||||
|
|
||||||
app.whenReady().then(() => {
|
app.whenReady().then(() => {
|
||||||
|
@ -122,7 +122,7 @@ Example:
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { app, net, protocol } = require('electron')
|
const { app, net, protocol } = require('electron')
|
||||||
const { join } = require('path')
|
const { join } = require('node:path')
|
||||||
const { pathToFileURL } = require('url')
|
const { pathToFileURL } = require('url')
|
||||||
|
|
||||||
protocol.registerSchemesAsPrivileged([
|
protocol.registerSchemesAsPrivileged([
|
||||||
|
|
|
@ -103,7 +103,7 @@ const { session } = require('electron')
|
||||||
session.defaultSession.on('will-download', (event, item, webContents) => {
|
session.defaultSession.on('will-download', (event, item, webContents) => {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
require('got')(item.getURL()).then((response) => {
|
require('got')(item.getURL()).then((response) => {
|
||||||
require('fs').writeFileSync('/somewhere', response.body)
|
require('node:fs').writeFileSync('/somewhere', response.body)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
@ -1193,7 +1193,7 @@ automatically. To clear the handler, call `setBluetoothPairingHandler(null)`.
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { app, BrowserWindow, session } = require('electron')
|
const { app, BrowserWindow, session } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
function createWindow () {
|
function createWindow () {
|
||||||
let bluetoothPinCallback = null
|
let bluetoothPinCallback = null
|
||||||
|
@ -1457,7 +1457,7 @@ extension to be loaded.
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { app, session } = require('electron')
|
const { app, session } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
app.whenReady().then(async () => {
|
app.whenReady().then(async () => {
|
||||||
await session.defaultSession.loadExtension(
|
await session.defaultSession.loadExtension(
|
||||||
|
@ -1544,7 +1544,7 @@ A [`Protocol`](protocol.md) object for this session.
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { app, session } = require('electron')
|
const { app, session } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
app.whenReady().then(() => {
|
app.whenReady().then(() => {
|
||||||
const protocol = session.fromPartition('some-partition').protocol
|
const protocol = session.fromPartition('some-partition').protocol
|
||||||
|
|
|
@ -1638,9 +1638,9 @@ An example of `webContents.printToPDF`:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { BrowserWindow } = require('electron')
|
const { BrowserWindow } = require('electron')
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
const os = require('os')
|
const os = require('node:os')
|
||||||
|
|
||||||
const win = new BrowserWindow()
|
const win = new BrowserWindow()
|
||||||
win.loadURL('https://github.com')
|
win.loadURL('https://github.com')
|
||||||
|
|
|
@ -42,14 +42,14 @@ $ asar list /path/to/example.asar
|
||||||
Read a file in the ASAR archive:
|
Read a file in the ASAR archive:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
fs.readFileSync('/path/to/example.asar/file.txt')
|
fs.readFileSync('/path/to/example.asar/file.txt')
|
||||||
```
|
```
|
||||||
|
|
||||||
List all files under the root of the archive:
|
List all files under the root of the archive:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
fs.readdirSync('/path/to/example.asar')
|
fs.readdirSync('/path/to/example.asar')
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -99,7 +99,7 @@ You can also set `process.noAsar` to `true` to disable the support for `asar` in
|
||||||
the `fs` module:
|
the `fs` module:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
process.noAsar = true
|
process.noAsar = true
|
||||||
fs.readFileSync('/path/to/example.asar')
|
fs.readFileSync('/path/to/example.asar')
|
||||||
```
|
```
|
||||||
|
|
|
@ -260,7 +260,7 @@ To create a custom driver, we'll use Node.js' [`child_process`](https://nodejs.o
|
||||||
The test suite will spawn the Electron process, then establish a simple messaging protocol:
|
The test suite will spawn the Electron process, then establish a simple messaging protocol:
|
||||||
|
|
||||||
```js title='testDriver.js' @ts-nocheck
|
```js title='testDriver.js' @ts-nocheck
|
||||||
const childProcess = require('child_process')
|
const childProcess = require('node:child_process')
|
||||||
const electronPath = require('electron')
|
const electronPath = require('electron')
|
||||||
|
|
||||||
// spawn the process
|
// spawn the process
|
||||||
|
|
|
@ -136,7 +136,7 @@ Finally, the `main.js` file represents the main process and contains the actual
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { app, BrowserWindow, ipcMain, nativeTheme } = require('electron')
|
const { app, BrowserWindow, ipcMain, nativeTheme } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
|
|
@ -35,8 +35,8 @@ Using the [React Developer Tools][react-devtools] as an example:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { app, session } = require('electron')
|
const { app, session } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
const os = require('os')
|
const os = require('node:os')
|
||||||
|
|
||||||
// on macOS
|
// on macOS
|
||||||
const reactDevToolsPath = path.join(
|
const reactDevToolsPath = path.join(
|
||||||
|
|
|
@ -52,7 +52,7 @@ In the main process, set an IPC listener on the `set-title` channel with the `ip
|
||||||
|
|
||||||
```javascript {6-10,22} title='main.js (Main Process)'
|
```javascript {6-10,22} title='main.js (Main Process)'
|
||||||
const { app, BrowserWindow, ipcMain } = require('electron')
|
const { app, BrowserWindow, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
// ...
|
// ...
|
||||||
|
|
||||||
|
@ -183,7 +183,7 @@ provided to the renderer process. Please refer to
|
||||||
|
|
||||||
```javascript {6-13,25} title='main.js (Main Process)'
|
```javascript {6-13,25} title='main.js (Main Process)'
|
||||||
const { app, BrowserWindow, dialog, ipcMain } = require('electron')
|
const { app, BrowserWindow, dialog, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
// ...
|
// ...
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ target renderer.
|
||||||
|
|
||||||
```javascript {11-26} title='main.js (Main Process)'
|
```javascript {11-26} title='main.js (Main Process)'
|
||||||
const { app, BrowserWindow, Menu, ipcMain } = require('electron')
|
const { app, BrowserWindow, Menu, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
function createWindow () {
|
function createWindow () {
|
||||||
const mainWindow = new BrowserWindow({
|
const mainWindow = new BrowserWindow({
|
||||||
|
|
|
@ -27,7 +27,7 @@ control our application lifecycle and create a native browser window.
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { app, BrowserWindow, shell } = require('electron')
|
const { app, BrowserWindow, shell } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
```
|
```
|
||||||
|
|
||||||
Next, we will proceed to register our application to handle all "`electron-fiddle://`" protocols.
|
Next, we will proceed to register our application to handle all "`electron-fiddle://`" protocols.
|
||||||
|
|
|
@ -303,7 +303,7 @@ without having to step through the isolated world.
|
||||||
|
|
||||||
```js title='main.js (Main Process)'
|
```js title='main.js (Main Process)'
|
||||||
const { BrowserWindow, app, MessageChannelMain } = require('electron')
|
const { BrowserWindow, app, MessageChannelMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
app.whenReady().then(async () => {
|
app.whenReady().then(async () => {
|
||||||
// Create a BrowserWindow with contextIsolation enabled.
|
// Create a BrowserWindow with contextIsolation enabled.
|
||||||
|
|
|
@ -22,7 +22,7 @@ In `preload.js` use the [`contextBridge`][] to inject a method `window.electron.
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { contextBridge, ipcRenderer } = require('electron')
|
const { contextBridge, ipcRenderer } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
contextBridge.exposeInMainWorld('electron', {
|
contextBridge.exposeInMainWorld('electron', {
|
||||||
startDrag: (fileName) => {
|
startDrag: (fileName) => {
|
||||||
|
|
|
@ -41,7 +41,7 @@ To enable this mode, GPU acceleration has to be disabled by calling the
|
||||||
|
|
||||||
```javascript fiddle='docs/fiddles/features/offscreen-rendering'
|
```javascript fiddle='docs/fiddles/features/offscreen-rendering'
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
|
|
||||||
app.disableHardwareAcceleration()
|
app.disableHardwareAcceleration()
|
||||||
|
|
||||||
|
|
|
@ -174,7 +174,7 @@ equally fictitious `foo-parser` module. In traditional Node.js development,
|
||||||
you might write code that eagerly loads dependencies:
|
you might write code that eagerly loads dependencies:
|
||||||
|
|
||||||
```js title='parser.js' @ts-expect-error=[2]
|
```js title='parser.js' @ts-expect-error=[2]
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
const fooParser = require('foo-parser')
|
const fooParser = require('foo-parser')
|
||||||
|
|
||||||
class Parser {
|
class Parser {
|
||||||
|
@ -198,7 +198,7 @@ do this work a little later, when `getParsedFiles()` is actually called?
|
||||||
|
|
||||||
```js title='parser.js' @ts-expect-error=[20]
|
```js title='parser.js' @ts-expect-error=[20]
|
||||||
// "fs" is likely already being loaded, so the `require()` call is cheap
|
// "fs" is likely already being loaded, so the `require()` call is cheap
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
|
|
||||||
class Parser {
|
class Parser {
|
||||||
async getFiles () {
|
async getFiles () {
|
||||||
|
|
|
@ -292,7 +292,7 @@ to the `webPreferences.preload` option in your existing `BrowserWindow` construc
|
||||||
```js
|
```js
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
// include the Node.js 'path' module at the top of your file
|
// include the Node.js 'path' module at the top of your file
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
// modify your existing createWindow() function
|
// modify your existing createWindow() function
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
|
@ -358,7 +358,7 @@ The full code is available below:
|
||||||
|
|
||||||
// Modules to control application life and create native browser window
|
// Modules to control application life and create native browser window
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
// Create the browser window.
|
// Create the browser window.
|
||||||
|
|
|
@ -26,8 +26,8 @@ the application via JumpList or dock menu, respectively.
|
||||||
|
|
||||||
```javascript fiddle='docs/fiddles/features/recent-documents'
|
```javascript fiddle='docs/fiddles/features/recent-documents'
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
const fs = require('fs')
|
const fs = require('node:fs')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
|
|
@ -29,7 +29,7 @@ To set the represented file of window, you can use the
|
||||||
|
|
||||||
```javascript fiddle='docs/fiddles/features/represented-file'
|
```javascript fiddle='docs/fiddles/features/represented-file'
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
const os = require('os')
|
const os = require('node:os')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
|
|
@ -83,7 +83,7 @@ To attach this script to your renderer process, pass its path to the
|
||||||
|
|
||||||
```js {2,8-10} title="main.js"
|
```js {2,8-10} title="main.js"
|
||||||
const { app, BrowserWindow } = require('electron')
|
const { app, BrowserWindow } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
@ -204,7 +204,7 @@ you send out the `invoke` call from the renderer.
|
||||||
|
|
||||||
```js {1,15} title="main.js"
|
```js {1,15} title="main.js"
|
||||||
const { app, BrowserWindow, ipcMain } = require('electron')
|
const { app, BrowserWindow, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
|
|
|
@ -184,7 +184,7 @@ allowing events such as `mouseleave` to be emitted:
|
||||||
|
|
||||||
```javascript title='main.js'
|
```javascript title='main.js'
|
||||||
const { BrowserWindow, ipcMain } = require('electron')
|
const { BrowserWindow, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const win = new BrowserWindow({
|
const win = new BrowserWindow({
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
|
|
|
@ -126,7 +126,7 @@ following lines:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { BrowserWindow, nativeImage } = require('electron')
|
const { BrowserWindow, nativeImage } = require('electron')
|
||||||
const path = require('path')
|
const path = require('node:path')
|
||||||
|
|
||||||
const win = new BrowserWindow()
|
const win = new BrowserWindow()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue