BrowserWindow
ブラウザウィンドウを作成したり、制御したりします。
Process: Main
app モジュールの ready イベントが発生するまでは、このモジュールは使用できません。
// メインプロセス
const { BrowserWindow } = require('electron')
const win = new BrowserWindow({ width: 800, height: 600 })
// 外部 URL を読み込む
win.loadURL('https://github.com')
// またはローカルの HTML ファイルを読み込む
win.loadURL('index.html')
ウインドウのカスタマイズ
BrowserWindow クラスは、アプリのウインドウの見た目や動作を変更するさまざまな方法を提供しています。 For more details, see the Window Customization tutorial.
ウインドウを違和感なく表示する
ウインドウにページを直接ロードすると、ユーザにはページが徐々にロードされるように見えるかもしれません。これはネイティブアプリとしては良い挙動ではありません。 ちらつかせることなくウインドウを表示するには、さまざまな状況に応じた 2 つの解決策があります。
ready-to-show イベントを使用する
ページのロード中、ウインドウがまだ表示されていない場合、レンダラープロセスが初めてページをレンダリングし終わったとき、ready-to-show イベントが発生します。 このイベントの後にウインドウを表示させれば、チラつくことはありません。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow({ show: false })
win.once('ready-to-show', () => {
  win.show()
})
このイベントは、通常、did-finish-load イベントの後に発生しますが、大量のリモートリソースがあるページでは、did-finish-load イベントの前に発生する可能性があります。
このイベントを使用すると、show が false でもレンダラーが "見えている" と見なされ、描画されることに注意してください。  paintWhenInitiallyHidden: false を使用すると、このイベントは発生しません。
backgroundColor プロパティを設定する
複雑なアプリでは、ready-to-show イベントが発生するのに時間がかかり過ぎて、アプリが遅いと感じさせる可能性があります。 このような場合、ウインドウをすぐに表示し、アプリの背景に近い backgroundColor を使うことを推奨します。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow({ backgroundColor: '#2e2c29' })
win.loadURL('https://github.com')
ready-to-show イベントを使用しているアプリに対しても、アプリがよりネイティブに感じられるように backgroundColor を設定することが推奨されます。
いくつか有効な backgroundColor の例を示します。
const win = new BrowserWindow()
win.setBackgroundColor('hsl(230, 100%, 50%)')
win.setBackgroundColor('rgb(255, 145, 145)')
win.setBackgroundColor('#ff00a3')
win.setBackgroundColor('blueviolet')
For more information about these color types see valid options in win.setBackgroundColor.
親ウィンドウと子ウィンドウ
parent オプションを使用することで、子ウインドウを作成することができます。
const { BrowserWindow } = require('electron')
const top = new BrowserWindow()
const child = new BrowserWindow({ parent: top })
child.show()
top.show()
child ウインドウは、常に top ウインドウの前面に表示されます。
モーダルウィンドウ
モーダルウインドウは、親ウインドウを無効にする子ウインドウです。 モーダルウインドウを作成するには、parent と modal の両方のオプションを設定しなければなりません。
const { BrowserWindow } = require('electron')
const top = new BrowserWindow()
const child = new BrowserWindow({ parent: top, modal: true, show: false })
child.loadURL('https://github.com')
child.once('ready-to-show', () => {
  child.show()
})
ページの表示状態
Page Visibility API は、以下のように動作します。
- すべてのプラットフォームおいて、表示状態はウインドウが非表示/最小化されているかどうかをトラッキングします。
- さらに、macOSでは、表示状態はウインドウが重なり合った状態もトラッキングします。 ウインドウが別のウインドウと重なり合った (例えば、完全に覆い隠された) 場合、表示状態は、hiddenになります。 他のプラットフォーム上では、ウインドウが最小化されるか、明示的にwin.hide()で非表示にされた場合のみ、表示状態はhiddenになります。
- BrowserWindowが- show: falseで作成された場合、ウインドウが実際には非表示であるにも関わらず、初期の表示状態は- visibleになります。
- backgroundThrottlingが無効の場合、ウインドウを最小化したり、重ねたり、非表示にしたりしても、表示状態は- visibleのままになります。
消費電力を最小にするために、表示状態が hidden のとき、高負荷な操作を一時停止することを推奨します。
プラットフォームに関する注意事項
- macOSでは、モーダルウインドウは親ウインドウに付随したシートとして表示されます。
- 親ウインドウが移動したとき、macOSでは、子ウインドウは親ウインドウに対する相対的な位置を維持しますが、WindowsとLinuxでは、子ウインドウは移動しません。
- Linuxでは、モーダルウインドウの型は、dialogに変更されます。
- Linuxでは、多くのデスクトップ環境は、モーダルウインドウを非表示にすることをサポートしていません。
クラス: BrowserWindow extends BaseWindow
ブラウザウィンドウを作成したり、制御したりします。
Process: Main
BrowserWindow は EventEmitter を継承しています。
options によって設定されたネイティブプロパティで新しい BrowserWindow を生成します。
[!WARNING] Electron's built-in classes cannot be subclassed in user code. For more information, see the FAQ.
new BrowserWindow([options])
インスタンスイベント
new BrowserWindow で作成されたオブジェクトでは以下のイベントが発生します。
[!NOTE] Some events are only available on specific operating systems and are labeled as such.
イベント: 'page-title-updated'
戻り値:
- eventEvent
- titlestring
- explicitSetboolean
ドキュメントのタイトルが変更されたときに発生します。event.preventDefault() を呼び出すことで、ネイティブウインドウのタイトルが変更されるのをキャンセルできます。 タイトルがファイルの URL から合成された場合、explicitSet は false です。
イベント: 'close'
戻り値:
- eventEvent
ウインドウがクローズされようとするときに発生します。 これは、DOMの beforeunload と unload イベントの前に発生します。 event.preventDefault() を呼び出すことで、クローズがキャンセルされます。
通常、ウインドウをクローズさせる必要があるかどうかを判断するために、beforeunload ハンドラーを使用したいと思うでしょうが、これは、ウインドウがリロードされるときにも呼び出されます。 Electronでは、undefined 以外の値を返却すれば、クローズをキャンセルします。 以下がその例です。
window.onbeforeunload = (e) => {
  console.log('I do not want to be closed')
  // メッセージボックスがユーザに表示される通常のブラウザーとは違って、
  // 無効でない値を返却すれば、何も表示せずにクローズをキャンセルします。
  // アプリケーションがクローズするのをユーザに確認させるには、
  // ダイアログAPIを使用することを推奨します。
  e.returnValue = false
}
[!NOTE] There is a subtle difference between the behaviors of
window.onbeforeunload = handlerandwindow.addEventListener('beforeunload', handler). It is recommended to always set theevent.returnValueexplicitly, instead of only returning a value, as the former works more consistently within Electron.
イベント: 'closed'
ウインドウが閉じられたときに発生します。 このイベントを受け取った後は、ウインドウへの参照を削除し、以降そのウインドウを使用しないようにしてください。
Event: 'query-session-end' Windows
戻り値:
- eventWindowSessionEndEvent
Emitted when a session is about to end due to a shutdown, machine restart, or user log-off. Calling event.preventDefault() can delay the system shutdown, though it’s generally best to respect the user’s choice to end the session. However, you may choose to use it if ending the session puts the user at risk of losing data.
イベント: 'session-end' Windows
戻り値:
- eventWindowSessionEndEvent
Emitted when a session is about to end due to a shutdown, machine restart, or user log-off. Once this event fires, there is no way to prevent the session from ending.
イベント: 'unresponsive'
Webページが応答しなくなるときに発生します。
イベント: 'responsive'
応答しないWebページが再び応答するようになるときに発生します。
イベント: 'blur'
ウインドウがフォーカスを失うときに発生します。
イベント: 'focus'
ウインドウがフォーカスを得るときに発生します。
イベント: 'show'
ウインドウが表示されるときに発生します。
イベント: 'hide'
ウインドウが非表示になるときに発生します。
イベント: 'ready-to-show'
Webページが (まだ表示されていないが) レンダリングされ、チラつくことなくウインドウが表示できるときに発生します。
このイベントを使用すると、show が false でもレンダラーが "見えている" と見なされ、描画されることに注意してください。  paintWhenInitiallyHidden: false を使用すると、このイベントは発生しません。
イベント: 'maximize'
ウィンドウが最大化されるときに発生します。
イベント: 'unmaximize'
ウインドウが最大化状態から抜けるときに発生します。
イベント: 'minimize'
ウィンドウが最小化されるときに発生します。
イベント: 'restore'
ウインドウが最小化状態から復元されたときに発生します。
イベント: 'will-resize' macOS Windows
戻り値:
- eventEvent
- newBoundsRectangle - Size the window is being resized to.
- detailsObject- edge(string) - サイズ変更のためにドラッグされているウインドウの縁。- bottom、- left、- right、- top-left、- top-right、- bottom-left、- bottom-rightのいずれかになります。
 
ウィンドウがリサイズされる前に発生します。 event.preventDefault()を呼び出すことで、ウィンドウがリサイズされるのを阻止できます。
このイベントは、ウィンドウが手動でリサイズされようとしているときにしか発生しません。 ウィンドウを、setBoundsやsetSize でリサイズする時には、このイベントは発生しません。
edge オプションに設定できる値と動作は、プラットフォーム依存です。 以下は取りうる値です。
- Windows では、有効な値は bottom、top、left、right、top-left、top-right、bottom-left、bottom-rightです。
- macOS では、有効な値は bottom、rightです。- 値 bottomは垂直方向のサイズ変更の表現に使用されます。
- 値 rightは水平方向のサイズ変更の表現に使用されます。
 
- 値 
イベント: 'resize'
ウインドウがリサイズされた後に発生します。
イベント: 'resized' macOS Windows
ウインドウがリサイズされるときに一度発生します。
これは、通常、ウィンドウが手動でリサイズされようとしているときにしか発生しません。 macOS の場合 setBounds/setSize でウィンドウのサイズを変更し、 animate パラメーターを true に設定すると、サイズ変更が完了したときにも、このイベントが発生します。
イベント: 'will-move' macOS Windows
戻り値:
- eventEvent
- newBoundsRectangle - Location the window is being moved to.
ウィンドウが移動される前に発生します。 Windows では、 event.preventDefault() を呼び出すことで、ウィンドウが移動されるのを阻止できます。
このイベントは、ウィンドウが手動で移動されようとしているときにしか発生しません。 ウインドウを setPosition/setBounds/center で移動する時には、このイベントは発生しません。
イベント: 'move'
ウインドウが新しい位置に移動されているときに発生します。
イベント: 'moved' macOS Windows
ウインドウが新しい位置に移動されるときに一回だけ、発生します。
[!NOTE] On macOS, this event is an alias of
move.
イベント: 'enter-full-screen'
ウインドウがフルスクリーン状態に入るときに発生します。
イベント: 'leave-full-screen'
ウインドウがフルスクリーン状態を抜けるときに発生します。
イベント: 'enter-html-full-screen'
ウインドウがHTML APIによってフルスクリーン状態に入るときに発生します。
イベント: 'leave-html-full-screen'
ウインドウがHTML APIによってフルスクリーン状態を抜けるときに発生します。
イベント: 'always-on-top-changed'
戻り値:
- eventEvent
- isAlwaysOnTopboolean
ウインドウが常に他のウインドウの手前に表示されるように設定またはそれが解除されたときに発生します。
イベント: 'app-command' Windows Linux
戻り値:
- eventEvent
- commandstring
Emitted when an App Command is invoked. これらは、Windowsで幾つかのマウスに組み込まれている "Back" ボタンだけでなく、一般的にキーボードのメディアキーやブラウザコマンドとも関連付けられています。
コマンドは小文字にされ、アンダースコアはハイフンに置き換えられ、APPCOMMAND_プレフィックスは外されます。 例えば、APPCOMMAND_BROWSER_BACKWARD は、browser-backward として送信されます。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow()
win.on('app-command', (e, cmd) => {
  // ユーザーがマウスで戻るボタンを押下したときにナビゲートする
  if (cmd === 'browser-backward' && win.webContents.canGoBack()) {
    win.webContents.goBack()
  }
})
Linux 上では以下のアプリコマンドが明示的にサポートされます。
- browser-backward
- browser-forward
イベント: 'swipe' macOS
戻り値:
- eventEvent
- directionstring
3 本指でのスワイプ時に発生します。 Possible directions are up, right, down, left.
このイベントは、スワイプで画面の内容が移動しない、古い macOS スタイルのトラックパッドスワイプを元にしています。 ほとんどの macOS トラックパッドはもうこの類のスワイプを許可していないため、正常にイベントを発生させるためには システム環境設定 > トラックパッド > その他のジェスチャ の 'ページ間をスワイプ' 設定を '2本指または3本指でスワイプ' にする必要があります。
イベント: 'rotate-gesture' macOS
戻り値:
- eventEvent
- rotationFloat
トラックパッドの回転ジェスチャで発生します。 回転ジェスチャーが終了するまで継続的に発生します。 各イベントの rotation 値は、最後の発生から回転した角度です。 回転ジェスチャで最後に発行されたイベントは、常に 0 の値になります。 反時計回りの回転値は正であり、時計回りの回転値は負です。
イベント: 'sheet-begin' macOS
ウインドウがシートを開くときに発生します。
イベント: 'sheet-end' macOS
ウインドウがシートを閉じたときに発生します。
イベント: 'new-window-for-tab' macOS
ネイティブの新規タブボタンがクリックされるときに発生します。
Event: 'system-context-menu' Windows Linux
戻り値:
- eventEvent
- pointPoint - The screen coordinates where the context menu was triggered.
システムコンテキストメニューがウィンドウ上でトリガーされたときに発生します。 通常ユーザーがウィンドウのクライアントエリア以外を右クリックしたときにトリガーされます。  これは、フレームレスウィンドウで-webkit-app-region: dragと宣言したウィンドウタイトルバーまたは任意の領域です。
event.preventDefault() を呼ぶと、そのメニューは表示されなくなります。
To convert point to DIP, use screen.screenToDipPoint(point).
静的メソッド
BrowserWindow クラスには、次の静的メソッドがあります。
BrowserWindow.getAllWindows()
戻り値 BrowserWindow[] - 開かれたすべてのブラウザウィンドウの配列。
BrowserWindow.getFocusedWindow()
戻り値 BrowserWindow | null - このアプリケーションでフォーカスされたウインドウ。それ以外は、null を返します。
BrowserWindow.fromWebContents(webContents)
- webContentsWebContents
戻り値 BrowserWindow | null - 指定された webContents を保持しているウインドウ。ウインドウが保持していないコンテンツの場合は null です。
BrowserWindow.fromBrowserView(browserView) Deprecated
- browserViewBrowserView
[!NOTE] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
戻り値 BrowserWindow - 指定された browserView を所有するウインドウ。 指定されたビューがどのウィンドウにもアタッチされていない場合は、 nullを返します。
BrowserWindow.fromId(id)
- idInteger
戻り値 BrowserWindow | null - 指定された id のウインドウ。
インスタンスプロパティ
new BrowserWindow で作成されたオブジェクトは、以下のプロパティを持っています。
const { BrowserWindow } = require('electron')
// この例では、 `win` がインスタンス
const win = new BrowserWindow({ width: 800, height: 600 })
win.loadURL('https://github.com')
win.webContents 読み出し専用
このウィンドウが所有する WebContents オブジェクト。 すべての Web ページ関連のイベントおよび操作は、これを介して行われます。
See the webContents documentation for its methods and events.
win.id 読み出し専用
Integer 型のプロパティです。そのウインドウの一意な ID を表します。 各 ID は、この Electron アプリケーション全体のすべての BrowserWindow インスタンス間で一意です。
win.tabbingIdentifier macOS 読み取り専用
string (任意) 型のプロパティで、BrowserWindow コンストラクタに渡された tabbingIdentifier と等しく、何も設定されていなければ undefined になります。
win.autoHideMenuBar Linux Windows
boolean 型のプロパティです。ウインドウがユーザーによって手動で最小化できるかどうかを決定します。 一度設定されると、メニューバーはユーザが単独で Alt キーを押したときのみに表示されます。
メニューバーが既に表示されている場合、このプロパティを true にセットしてもすぐに非表示にはなりません。
win.simpleFullScreen
boolean 型のプロパティです。ウインドウがシンプルな (Lion 以前の) フルスクリーンモードかどうかを決定します。
win.fullScreen
boolean 型のプロパティです。ウインドウがフルスクリーンモードかどうかを決定します。
win.focusable Windows macOS
boolean 型のプロパティです。ウインドウにフォーカスできるどうかを決定します。
win.visibleOnAllWorkspaces macOS Linux
boolean 型のプロパティです。ウインドウがすべてのワークスペースで表示されるどうかを決定します。
[!NOTE] Always returns false on Windows.
win.shadow
boolean 型のプロパティです。ウインドウに影があるかどうかを決定します。
win.menuBarVisible Windows Linux
boolean 型のプロパティです。メニューバーが表示されるかどうかを決定します。
[!NOTE] If the menu bar is auto-hide, users can still bring up the menu bar by pressing the single
Altkey.
win.kiosk
boolean 型のプロパティです。ウインドウがキオスクモードかどうかを決定します。
win.documentEdited macOS
boolean 型のプロパティです。ウインドウのドキュメントが編集されたかどうかを決定します。
true にすると、タイトルバーのアイコンが灰色になります。
win.representedFilename macOS
string 型のプロパティです。ウインドウが表すファイルのパス名を決定し、そのファイルのアイコンをウインドウのタイトルバーに表示します。
win.title
string 型のプロパティです。ネイティブウインドウのタイトルを決定します。
[!NOTE] The title of the web page can be different from the title of the native window.
win.minimizable macOS Windows
boolean 型のプロパティです。ウインドウがユーザーによって手動で最小化できるかどうかを決定します。
Linux ではセッターは何もしませんが、ゲッターは true を返します。
win.maximizable macOS Windows
boolean 型のプロパティです。ウインドウがユーザーによって手動で最大化できるかどうかを決定します。
Linux ではセッターは何もしませんが、ゲッターは true を返します。
win.fullScreenable
boolean 型のプロパティです。ウインドウを最大化/ズームするウインドウボタンでフルスクリーンモードや最大化をトグル切り替えできるかどうかを決定します。
win.resizable
boolean 型のプロパティです。ウインドウがユーザーによって手動でサイズ変更できるかどうかを決定します。
win.closable macOS Windows
boolean 型のプロパティです。ウインドウがユーザーによって手動で閉じることができるかどうかを決定します。
Linux ではセッターは何もしませんが、ゲッターは true を返します。
win.movable macOS Windows
boolean 型のプロパティです。ウインドウがユーザーによって移動できるかどうかを決定します。
Linux ではセッターは何もしませんが、ゲッターは true を返します。
win.excludedFromShownWindowsMenu macOS
boolean 型のプロパティです。ウインドウをアプリケーションの Windows メニューから除外するかどうかを決定します。 省略値は false です。
const win = new BrowserWindow({ height: 600, width: 600 })
const template = [
  {
    role: 'windowmenu'
  }
]
win.excludedFromShownWindowsMenu = true
const menu = Menu.buildFromTemplate(template)
Menu.setApplicationMenu(menu)
win.accessibleTitle
string 型のプロパティです。スクリーンリーダーなどのアクセシビリティツールにのみ提供される代替タイトルを定義します。 この文字列はユーザに直接表示されません。
win.snapped Windows Readonly
A boolean property that indicates whether the window is arranged via Snap.
インスタンスメソッド
new BrowserWindow で作成されたオブジェクトは、次のインスタンスメソッドを持っています。
[!NOTE] Some methods are only available on specific operating systems and are labeled as such.
win.destroy()
強制的にウインドウを閉じます。unload と beforeunload イベントはWebページで発生しません。また、close イベントもこのウインドウで発生しません。しかし、closed イベントが発生することは保証されます。
win.close()
ウインドウを閉じようとします。 これは、ユーザーが手動でウィンドウの閉じるボタンをクリックした場合と同じ効果があります。 ただし、 Web ページはウィンドウが閉じようとするのををキャンセルすることができます。 See the close event.
win.focus()
ウインドウにフォーカスを当てます。
win.blur()
ウインドウからフォーカスを外します。
win.isFocused()
戻り値 boolean - ウインドウがフォーカスされているかどうか。
win.isDestroyed()
戻り値 boolean - ウインドウが破棄されているかどうか。
win.show()
表示し、ウインドウにフォーカスを当てます。
win.showInactive()
ウインドウを表示しますが、フォーカスを当てません。
win.hide()
ウインドウを非表示にします。
win.isVisible()
戻り値 boolean - アプリのフォアグラウンドでそのウインドウがユーザーに見えるかどうか。
win.isModal()
戻り値 boolean - 現在のウインドウがモーダルウインドウかどうか。
win.maximize()
ウィンドウを最大化します。 ウインドウがまだ表示されていない場合、併せてウインドウを表示 (ただし、フォーカスは当たりません) します。
win.unmaximize()
ウインドウの最大化を解除します。
win.isMaximized()
戻り値 boolean - ウインドウが最大化されているかどうか。
win.minimize()
ウィンドウを最小化します。 一部のプラットフォームでは、最小化されたウィンドウが Dock に表示されます。
win.restore()
ウインドウを最小化された状態からその前の状態に戻します。
win.isMinimized()
戻り値 boolean - ウインドウが最小化されているかどうか。
win.setFullScreen(flag)
- flagboolean
ウインドウをフルスクリーンモードにするかどうかを設定します。
[!NOTE] On macOS, fullscreen transitions take place asynchronously. If further actions depend on the fullscreen state, use the 'enter-full-screen' or 'leave-full-screen' events.
win.isFullScreen()
戻り値 boolean - ウインドウがフルスクリーンモードであるかどうか。
[!NOTE] On macOS, fullscreen transitions take place asynchronously. BrowserWindow のフルスクリーン状態を確認するには、'enter-full-screen' または 'leave-full-screen' イベントのいずれかの発生を確かめる必要があります。
win.setSimpleFullScreen(flag) macOS
- flagboolean
簡易フルスクリーンモードに設定したり、解除したりします。
macOS Lion (10.7) より前のバージョンで見られる簡易フルスクリーンモードはネイティブのフルスクリーン動作をエミュレートします。
win.isSimpleFullScreen() macOS
戻り値 boolean - ウインドウが簡易 (Lion 以前の) フルスクリーンモードであるかどうか。
win.isNormal()
戻り値 boolean - ウインドウが通常の状態 (最大化されていない、最小化されていない、フルスクリーンモードでない) かどうか。
win.setAspectRatio(aspectRatio[, extraSize])
- aspectRatioFloat - コンテンツビューの一部を維持するためのアスペクト比。
- extraSizeSize (optional) macOS - The extra size not to be included while maintaining the aspect ratio.
これはウインドウのアスペクト比を維持します。 ピクセルで指定した追加のサイズによって、開発者は、アスペクト比の計算に含まれないスペースを確保することができます。 このAPIはウインドウのサイズとそのコンテンツのサイズの差異も考慮しています。
HDビデオプレーヤーと関連したコントロールを持つ通常のウインドウを考えてみましょう。 ひょっとすると、左端に15ピクセルのコントロール、右端に25ピクセルのコントロール、プレーヤーの下部に50ピクセルのコントロールがあるかもしれません。 プレーヤー内で 16:9 アスペクト比 (HD @1920x1280 の標準的なアスペクト比) を維持するためには、この関数を 16/9 と { width: 40, height: 50 } の引数で呼び出します。 2番目の引数は、追加の幅と高さがコンテンツビューの中に収まるかを気にしません。それらはただ存在しているだけです。 全体のコンテンツビュー内にある余分な幅と高さの領域を単純に足し合わせます。
win.setSize などの API でプログラム上からウインドウをサイズ変更した場合、アスペクト比は維持されません。
アスペクト比をリセットするには、aspectRatio の値として 0 を渡します。つまり、win.setAspectRatio(0) です。
win.setBackgroundColor(backgroundColor)
- backgroundColorstring - 16進数、RGB、RGBA、HSL、HSLA、または名前付き CSS カラーフォーマットの色。 16 進数タイプの場合のアルファチャンネルは任意です。
有効な backgroundColor の値の例を示します。
- Hex
- #fff (略記 RGB)
- #ffff (略記 ARGB)
- #ffffff (RGB)
- #ffffffff (ARGB)
 
- RGB
- rgb\(([\d]+),\s*([\d]+),\s*([\d]+)\)- 例: rgb(255, 255, 255)
 
 
- RGBA
- rgba\(([\d]+),\s*([\d]+),\s*([\d]+),\s*([\d.]+)\)- 例: rgba(255, 255, 255, 1.0)
 
 
- HSL
- hsl\((-?[\d.]+),\s*([\d.]+)%,\s*([\d.]+)%\)- 例: hsl(200, 20%, 50%)
 
 
- HSLA
- hsla\((-?[\d.]+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)- 例: hsla(200, 20%, 50%, 0.5)
 
 
- 色の名前
- 選択肢は SkParseColor.cpp に列挙してあります。
- CSS カラーモジュールレベル 3 のキーワードと似ていますが、大文字と小文字を区別します。
- 例: bluevioletやred
 
- 例: 
 
ウィンドウの背景色を設定します。 See Setting backgroundColor.
win.previewFile(path[, displayName]) macOS
- pathstring - クイックルックでプレビューするファイルへの絶対パス。 ここで、Quick Lookはパスのファイル名とファイル拡張子をファイルを開くためのコンテンツタイプを決定するのに使用する点が重要です。
- displayNamestring (任意) - クイックルックのモーダルビューに表示するファイルの名前。 これは純粋に見た目だけのもので、ファイルのコンテンツタイプには影響しません。 省略値は、- pathです。
Uses Quick Look to preview a file at a given path.
win.closeFilePreview() macOS
Closes the currently open Quick Look panel.
win.setBounds(bounds[, animate])
- boundsPartial<Rectangle>
- animateboolean (任意) macOS
指定した境界までウインドウのサイズを変更して移動します。 指定されていないプロパティは、既定で現在の値になります。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow()
// bounds のプロパティをすべて設定
win.setBounds({ x: 440, y: 225, width: 800, height: 600 })
// bounds のプロパティをひとつ設定
win.setBounds({ width: 100 })
// { x: 440, y: 225, width: 100, height: 600 }
console.log(win.getBounds())
[!NOTE] On macOS, the y-coordinate value cannot be smaller than the Tray height. Tray の高さは時期やオペレーティングシステムによって異なりますが、20 から 40px の間です。 Tray の高さより低い値を渡すと、Tray と同じ高さのウインドウになります。
win.getBounds()
Returns Rectangle - The bounds of the window as Object.
[!NOTE] On macOS, the y-coordinate value returned will be at minimum the Tray height. 例えば、トレイの高さを 38 にして
win.setBounds({ x: 25, y: 20, width: 800, height: 600 })を呼び出すと、win.getBounds()は{ x: 25, y: 38, width: 800, height: 600 }を返します。
win.getBackgroundColor()
戻り値 string - ウインドウの背景色を 16 進数 (#RRGGBB) 形式で取得します。
[!NOTE] The alpha value is not returned alongside the red, green, and blue values.
win.setContentBounds(bounds[, animate])
- boundsRectangle
- animateboolean (任意) macOS
指定した境界までウインドウのクライアント領域 (例えば、Webページ) のサイズを変更して移動します。
win.getContentBounds()
Returns Rectangle - The bounds of the window's client area as Object.
win.getNormalBounds()
Returns Rectangle - Contains the window bounds of the normal state
[!NOTE] Whatever the current state of the window (maximized, minimized or in fullscreen), this function always returns the position and size of the window in normal state. In normal state,
getBoundsandgetNormalBoundsreturn the same Rectangle.
win.setEnabled(enable)
- enableboolean
ウインドウを無効にするか有効にします。
win.isEnabled()
戻り値 boolean - そのウインドウが有効かどうか。
win.setSize(width, height[, animate])
- widthInteger
- heightInteger
- animateboolean (任意) macOS
ウインドウのサイズを width と height に変更します。 width または height が最小サイズ制約の設定値より低い場合、ウィンドウはその最小サイズにスナップします。
win.getSize()
戻り値 Integer[] - ウインドウの幅と高さを含みます。
win.setContentSize(width, height[, animate])
- widthInteger
- heightInteger
- animateboolean (任意) macOS
ウインドウのクライアント領域 (例えば、Webページ) のサイズを width と height に変更します。
win.getContentSize()
戻り値 Integer[] - ウインドウのクライアント領域の幅と高さを含みます。
win.setMinimumSize(width, height)
- widthInteger
- heightInteger
ウインドウの最小サイズを width と height に設定します。
win.getMinimumSize()
戻り値 Integer[] - ウインドウの最小の幅と高さを含みます。
win.setMaximumSize(width, height)
- widthInteger
- heightInteger
ウインドウの最大サイズを width と height に設定します。
win.getMaximumSize()
戻り値 Integer[] - ウインドウの最大の幅と高さを含みます。
win.setResizable(resizable)
- resizableboolean
ウインドウがユーザによって手動でサイズ変更できるかどうかを設定します。
win.isResizable()
戻り値 boolean - ウインドウがユーザによって手動でサイズ変更できるかどうか。
win.setMovable(movable) macOS Windows
- movableboolean
ウインドウがユーザーによって手動で移動できるかどうかを設定します。 Linux では何もしません。
win.isMovable() macOS Windows
戻り値 boolean - ウインドウがユーザーによって移動できるかどうか。
Linuxでは常に true を返します。
win.setMinimizable(minimizable) macOS Windows
- minimizableboolean
ウインドウがユーザーによって手動で最小化できるかどうかを設定します。 Linux では何もしません。
win.isMinimizable() macOS Windows
戻り値 boolean - ウインドウがユーザによって手動で最小化できるかどうか。
Linuxでは常に true を返します。
win.setMaximizable(maximizable) macOS Windows
- maximizableboolean
ウインドウがユーザーによって手動で最大化できるかどうかを設定します。 Linux では何もしません。
win.isMaximizable() macOS Windows
戻り値 boolean - ウインドウがユーザーによって手動で最大化できるかどうか。
Linuxでは常に true を返します。
win.setFullScreenable(fullscreenable)
- fullscreenableboolean
ウインドウの最大化/ズームボタンでフルスクリーンモードに切り替えるか、ウインドウを最大化するかを設定します。
win.isFullScreenable()
戻り値 boolean - ウインドウの最大化/ズームボタンでフルスクリーンモードに切り替えるのか、それともウインドウを最大化するのか。
win.setClosable(closable) macOS Windows
- closableboolean
ウインドウがユーザーによって手動で閉じられるかどうかを設定します。 Linux では何もしません。
win.isClosable() macOS Windows
戻り値 boolean - ウインドウをユーザーが手動で閉じられるかどうか。
Linuxでは常に true を返します。
win.setHiddenInMissionControl(hidden) macOS
- hiddenboolean
ユーザーが Mission Control に切り替えたときに、このウインドウを隠すかどうかを設定します。
win.isHiddenInMissionControl() macOS
戻り値 boolean - ユーザーが Mission Control に切り替えたときに、このウインドウを非表示にするかどうかです。
win.setAlwaysOnTop(flag[, level][, relativeLevel])
- flagboolean
- levelstring (任意) macOS Windows - 値は、- normal、- floating、- torn-off-menu、- modal-panel、- main-menu、- status、- pop-up-menu、- screen-saverと- dock- flagが true の場合、省略値は- floatingです。 flag が false の場合、- levelは- normalにリセットされます。- floatingから- statusまでに含まれているものにおいて、ウィンドウは macOS では Dock の下に、Windows ではタスクバーの下に配置されることをことに注意してください。- pop-up-menu以降は、macOS では Dock の上に、Windows ではタスクバーの上に表示されます。 詳細については、macOS のドキュメント をご参照ください。
- relativeLevelInteger (任意) macOS - このウインドウを指定した- levelから相対的により高いレイヤーへ設定するための数です。 省略値は、- 0です。 Apple社は、- screen-saverより上に1以上のレベルを設定することを推奨していないことに注意してください。
ウィンドウを常に他のウィンドウの上に表示するかどうかを設定します。 この設定を行った後でも、ウィンドウはまだ通常のものであり、フォーカスが当てられないツールボックスウィンドウではありません。
win.isAlwaysOnTop()
戻り値 boolean - ウインドウが常に他のウインドウの上に表示されるかどうか。
win.moveAbove(mediaSourceId)
- mediaSourceIdstring - DesktopCapturerSource の ID の形式のウィンドウ ID。 例えば "window:1869:0" 。
Z オーダーの意味で、ウィンドウをソースウィンドウの上に移動します。 mediaSourceId がウィンドウの ID でないか、ウィンドウが存在しない場合、このメソッドはエラーをスローします。
win.moveTop()
フォーカスに関係なく上 (Z順序) にウィンドウを移動します。
win.center()
ウインドウを画面の中央に移動します。
win.setPosition(x, y[, animate])
- xInteger
- yInteger
- animateboolean (任意) macOS
Moves window to x and y.
win.getPosition()
戻り値 Integer[] - ウインドウの現在の位置を含みます。
win.setTitle(title)
- titlestring
ネイティブのウインドウのタイトルを title に変更します。
win.getTitle()
戻り値 string - ネイティブウインドウのタイトル。
[!NOTE] The title of the web page can be different from the title of the native window.
win.setSheetOffset(offsetY[, offsetX]) macOS
- offsetYFloat
- offsetXFloat (optional)
macOS においてシートを設置する位置を変更します。 既定では、シートはウィンドウフレームのすぐ下に設置されますが、 HTML で表示されたツールバーの下に表示することもできます。 以下がその例です。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow()
const toolbarRect = document.getElementById('toolbar').getBoundingClientRect()
win.setSheetOffset(toolbarRect.height)
win.flashFrame(flag)
History
| Version(s) | Changes | 
|---|---|
| None | macOS で  | 
- flagboolean
ユーザの注意を引きつけるためにウインドウの点滅を開始または停止します。
win.setSkipTaskbar(skip) macOS Windows
- skipboolean
ウインドウがタスクバーに表示されなくなります。
win.setKiosk(flag)
- flagboolean
キオスクモードに入ったり出たりします。
win.isKiosk()
戻り値 boolean - ウインドウがキオスクモードであるかどうか。
win.isTabletMode() Windows
戻り値 boolean - ウインドウが Windows 10 タブレットモードであるかどうか。
Since Windows 10 users can use their PC as tablet, under this mode apps can choose to optimize their UI for tablets, such as enlarging the titlebar and hiding titlebar buttons.
この API は、ウインドウがタブレットモードかどうかを返します。resize イベントでタブレットモードへの変更をリッスンすることもできます。
win.getMediaSourceId()
戻り値 string - DesktopCapturerSource の ID の形式のウィンドウ ID。 例えば "window:1324:0" 。
より正確には、フォーマットは  window:id:other_id です。ここでの id は、Windows では HWND、macOS では CGWindowID (uint64_t)、Linux では Window (unsigned long) です。 other_id は、同じトップレベルウィンドウ内のウェブコンテンツ (タブ) を識別するために使用されます。
win.getNativeWindowHandle()
戻り値 Buffer - ウインドウのプラットフォーム固有のハンドル。
ハンドルのネイティブな型は、Windowsでは HWND、macOSでは NSView*、Linuxでは Window (unsigned long) です。
win.hookWindowMessage(message, callback) Windows
- messageInteger
- callbackFunction- wParamBuffer - WndProc に指定された- wParam
- lParamBuffer - WndProc に指定された- lParam
 
ウィンドウメッセージをフックします。 メッセージが WndProc で受信されると、 callback が呼び出されます。
win.isWindowMessageHooked(message) Windows
- messageInteger
戻り値 boolean - メッセージがフックされているかどうかによって、true または false 。
win.unhookWindowMessage(message) Windows
- messageInteger
ウインドウメッセージのフックを解除します。
win.unhookAllWindowMessages() Windows
すべてのウインドウメッセージのフックを解除します。
win.setRepresentedFilename(filename) macOS
- filenamestring
ウインドウが表すファイルのパス名を設定します。ファイルのアイコンがウインドウのタイトルバーに表示されます。
win.getRepresentedFilename() macOS
戻り値 string - ウインドウが表すファイルのパス名。
win.setDocumentEdited(edited) macOS
- editedboolean
ウインドウのドキュメントが編集されたかどうかを指定します。true に設定すると、タイトルバーのアイコンがグレーになります。
win.isDocumentEdited() macOS
戻り値 boolean - ウインドウのドキュメントが編集されたかどうか。
win.focusOnWebView()
win.blurWebView()
win.capturePage([rect, opts])
- rectRectangle (optional) - The bounds to capture
- optsObject (任意)- stayHiddenboolean (任意) - ページを表示せずに非表示のままにします。 省略値は- falseです。
- stayAwakeboolean (任意) - システムをスリープさせずに、起きたままにします。 省略値は- falseです。
 
戻り値 Promise<NativeImage> - NativeImage を解決します
rect 内のページのスナップショットをキャプチャします。 rect を省略すると、表示されているページ全体をキャプチャします。 ページが表示されない場合、 rect が空である可能性があります。 ブラウザーウインドウが非表示でもキャプチャ回数がゼロではない場合、ページは表示されていると見なされます。 ページを非表示のままにする場合は、stayHidden を true に設定していることを確認してください。
win.loadURL(url[, options])
- urlstring
戻り値 Promise<void> - ページ読み込みが完了した時 (did-finish-load を参照) に解決され、ページの読み込みに失敗した時 (did-fail-load を参照) に拒否される Promise。
Same as webContents.loadURL(url[, options]).
url は、リモートアドレス (例えば、http://) または file:// プロトコルを使ってローカルのHTMLファイルのパスにすることができます。
To ensure that file URLs are properly formatted, it is recommended to use Node's url.format method:
const { BrowserWindow } = require('electron')
const win = new BrowserWindow()
const url = require('node:url').format({
  protocol: 'file',
  slashes: true,
  pathname: require('node:path').join(__dirname, 'index.html')
})
win.loadURL(url)
次のようにすることによって、URLエンコードされたデータで POST リクエストを使用してURLをロードすることができます。
const { BrowserWindow } = require('electron')
const win = new BrowserWindow()
win.loadURL('http://localhost:8000/post', {
  postData: [{
    type: 'rawData',
    bytes: Buffer.from('hello=world')
  }],
  extraHeaders: 'Content-Type: application/x-www-form-urlencoded'
})
win.loadFile(filePath[, options])
- filePathstring
戻り値 Promise<void> - ページ読み込みが完了した時 (did-finish-load を参照) に解決され、ページの読み込みに失敗した時 (did-fail-load を参照) に拒否される Promise。
webContents.loadFile と同じく、 filePath はアプリケーションのルートからの HTML ファイルへの相対パスである必要があります。  詳しくは、 webContents ドキュメントを参照してください。
win.reload()
webContents.reload と同じです。
win.setMenu(menu) Linux Windows
- menuMenu | null
menu をウインドウのメニューバーとして設定します。
win.removeMenu() Linux Windows
ウインドウのメニューバーを消去します。
win.setProgressBar(progress[, options])
- progressDouble
プログレスバーの進捗を設定します。 有効な範囲は [0, 1.0] です。
進捗 < 0 の場合、プログレスバーは削除されます。進捗 > 1 の場合、不確定モードに変更します。
Linuxプラットフォームでは、Unityデスクトップ環境のみがサポートされ、package.json の desktopName フィールドに *.desktop ファイル名を指定する必要があります。 既定では、{app.name}.desktop であるとみなされます。
Windowsでは、モードを渡すことができます。 Accepted values are none, normal, indeterminate, error, and paused. モードを設定せずに (ただし、有効範囲内の値で) setProgressBar を呼び出した場合、normal とみなされます。
win.setOverlayIcon(overlay, description) Windows
- overlayNativeImage | null - the icon to display on the bottom right corner of the taskbar icon. この引数が- nullの場合、オーバーレイは消去されます。
- descriptionstring - アクセシビリティスクリーンリーダーに提供される説明
現在のタスクバーアイコンの上に、通常、何らかのアプリケーションステータスを伝えたり、ユーザーに控えめに通知したりするのに使われる16 x 16ピクセルのオーバレイを設定します。
win.invalidateShadow() macOS
ウインドウの影を現在のウインドウの形状に基づいて再計算するように更新します。
透明な BrowserWindows では、macOS で視覚的な残留物を残すことがあります。 このメソッドは、例えばアニメーションを実行するときにこれらの残留物を消去するときに利用できます。
win.setHasShadow(hasShadow)
- hasShadowboolean
ウインドウに影を付けるべきかどうかを設定します。
win.hasShadow()
戻り値 boolean - ウインドウに影を表示させているかどうか。
win.setOpacity(opacity) Windows macOS
- opacitynumber - 0.0 (完全に透明) と 1.0 (完全に不透明) の間
ウィンドウの不透明度を設定します。 Linux では何もしません。 範囲外の値は [0, 1] に収められます。
win.getOpacity()
戻り値 number - 0.0 (完全に透明) と 1.0 (完全に不透明) の間です。 Linuxでは常に 1 を返します。
win.setShape(rects) Windows Linux 実験的
- rectsRectangle[] - Sets a shape on the window. 空のリストを渡すと、ウィンドウが四角形に戻ります。
ウィンドウの形を設定すると、システム内で描画とユーザ操作が許可されているウィンドウ内の領域が決まります。 与えられた領域の外側のピクセルでは描画されず、マウスイベントも登録されません。 領域外のマウスイベントはそのウィンドウでは受信されませんが、ウィンドウの後ろにあるものにそのイベントがフォールスルーします。
win.setThumbarButtons(buttons) Windows
- buttonsThumbarButton[]
戻り値 boolean - ボタンの追加に成功したかどうか
タスクバーボタンレイアウトのウインドウのサムネイルイメージに指定されたボタンのセットと一緒にサムネイルツールバーを追加します。 戻り値の boolean オブジェクトは、サムネイルの追加に成功したかどうかを示します。
限られた空間のため、サムネイルツールバーのボタン数は、7以下にしてください。 一度、サムネイルツールバーをセットアップすると、プラットフォームの制約のため、ツールバーを削除することはできません。 しかしながら、ボタンを取り除くためにAPIを空の配列で呼び出すことはできます。
buttons は、Button オブジェクトの配列です。
- ButtonObject- iconNativeImage - The icon showing in thumbnail toolbar.
- clickFunction
- tooltipstring (任意) - ボタンのツールチップのテキスト。
- flagsstring[] (任意) - ボタンの特定の状態や動作を制御します。 省略値は、- ['enabled']です。
 
flags は、以下の string を含めることができる配列です。
- enabled- ボタンはアクティブで、ユーザーが使用できます。
- disabled- そのボタンは無効化されます。 存在しますが、ユーザ操作に応答しないことを示す視覚的な状態です。
- dismissonclick- そのボタンをクリックすると、サムネイルウインドウがすぐに閉じます。
- nobackground- そのボタンの縁を描画しません。画像にのみ使用してください。
- hidden- そのボタンはユーザに表示されません。
- noninteractive- そのボタンは有効ですが、反応せず、押されたボタンの状態も描画されません。 この値は、例えば通知内で使用するボタンに使用されます。
win.setThumbnailClip(region) Windows
- regionRectangle - Region of the window
タスクバーのウインドウの上でホバリングするときに表示されるサムネイルイメージとして表示するウインドウの領域を設定します。 空の領域: { x: 0, y: 0, width: 0, height: 0 } を指定することで、サムネイルをウインドウ全体にリセットすることができます。
win.setThumbnailToolTip(toolTip) Windows
- toolTipstring
タスクバーのウインドウサムネイルでホバリングするときに表示されるツールチップを設定します。
win.setAppDetails(options) Windows
ウインドウのタスクバーボタンのプロパティを設定します。
relaunchCommand and relaunchDisplayName must always be set together. いずれかが設定されていない場合、どちらも使用されません。
win.setAccentColor(accentColor) Windows
- accentColorboolean | string - The accent color for the window. By default, follows user preference in System Settings.
Sets the system accent color and highlighting of active window border.
The accentColor parameter accepts the following values:
- Color string - Sets a custom accent color using standard CSS color formats (Hex, RGB, RGBA, HSL, HSLA, or named colors). Alpha values in RGBA/HSLA formats are ignored and the color is treated as fully opaque.
- true- Uses the system's default accent color from user preferences in System Settings.
- false- Explicitly disables accent color highlighting for the window.
例:
const win = new BrowserWindow({ frame: false })
// Set red accent color.
win.setAccentColor('#ff0000')
// RGB format (alpha ignored if present).
win.setAccentColor('rgba(255,0,0,0.5)')
// Use system accent color.
win.setAccentColor(true)
// Disable accent color.
win.setAccentColor(false)
win.getAccentColor() Windows
Returns string | boolean - the system accent color and highlighting of active window border in Hex RGB format.
If a color has been set for the window that differs from the system accent color, the window accent color will be returned. Otherwise, a boolean will be returned, with true indicating that the window uses the global system accent color, and false indicating that accent color highlighting is disabled for this window.
win.showDefinitionForSelection() macOS
webContents.showDefinitionForSelection() と同じです。
win.setIcon(icon) Windows Linux
- iconNativeImage | string
ウインドウのアイコンを変更します。
win.setWindowButtonVisibility(visible) macOS
- visibleboolean
ウインドウの信号ボタンを表示するかどうかを設定します。
win.setAutoHideMenuBar(hide) Windows Linux
- hideboolean
ウィンドウのメニューバーを自動的に非表示にするかどうかを設定します。 一度設定されると、メニューバーはユーザが単独で Alt キーを押したときのみに表示されます。
メニューバーが既に表示されている場合、setAutoHideMenuBar(true) を呼び出してもすぐに非表示にはなりません。
win.isMenuBarAutoHide() Windows Linux
戻り値 boolean - メニューバーを自動的に非表示にするかどうか。
win.setMenuBarVisibility(visible) Windows Linux
- visibleboolean
メニューバーを表示するかどうかを設定します。 メニューバーが自動的に非表示にされている場合でも、ユーザが単に Alt キーを押下すれば、依然としてメニューバーを表示させることができます。
win.isMenuBarVisible() Windows Linux
戻り値 boolean - メニューバーを表示しているかどうか。
win.isSnapped() Windows
Returns boolean - whether the window is arranged via Snap.
The window is snapped via buttons shown when the mouse is hovered over window maximize button, or by dragging it to the edges of the screen.
win.setVisibleOnAllWorkspaces(visible[, options]) macOS Linux
- visibleboolean
ウインドウをすべてのワークスペースで表示させるかどうかを設定します。
[!NOTE] This API does nothing on Windows.
win.isVisibleOnAllWorkspaces() macOS Linux
戻り値 boolean - ウインドウがすべてのワークスペースで表示されているかどうか。
[!NOTE] This API always returns false on Windows.
win.setIgnoreMouseEvents(ignore[, options])
- ignoreboolean
ウインドウがすべてのマウスイベントを無視するようにします。
このウインドウで発生するすべてのマウスイベントは、このウインドウの下にあるウインドウに渡されますが、このウインドウにフォーカスがある場合、依然としてキーボードイベントは受信されます。
win.setContentProtection(enable) macOS Windows
- enableboolean
他のアプリによってウインドウのコンテンツがキャプチャされるのを防止します。
On Windows, it calls SetWindowDisplayAffinity with WDA_EXCLUDEFROMCAPTURE. Windows 10 バージョン 2004 以降からウインドウのキャプチャが完全に削除されましたが、古い Windows バージョンで WDA_MONITOR が適用された場合は黒いウィンドウをキャプチャするように動作します。
On macOS, it sets the NSWindow's sharingType to NSWindowSharingNone. Unfortunately, due to an intentional change in macOS, newer Mac applications that use ScreenCaptureKit will capture your window despite win.setContentProtection(true). See here.
win.isContentProtected() macOS Windows
Returns boolean - whether or not content protection is currently enabled.
win.setFocusable(focusable) macOS Windows
- focusableboolean
ウインドウにフォーカスできるかどうかを変更します。
macOS ではウィンドウからフォーカスは除去されません。
win.isFocusable() macOS Windows
戻り値 boolean - ウインドウにフォーカスできるかどうか。
win.setParentWindow(parent)
- parentBrowserWindow | null
現在のウインドウの親ウインドウとして parent を設定します。null を渡すと、現在のウインドウをトップレベルウインドウにします。
win.getParentWindow()
戻り値 BrowserWindow | null - 親ウインドウ、もしくは親が無ければ null です。
win.getChildWindows()
戻り値 BrowserWindow[] - すべての子ウインドウ。
win.setAutoHideCursor(autoHide) macOS
- autoHideboolean
タイプしているときにカーソルを非表示にするかどうかを制御します。
win.selectPreviousTab() macOS
ネイティブのタブが有効で、ウインドウに他のタブがあるとき、一つ前のタブを選択します。
win.selectNextTab() macOS
ネイティブのタブが有効で、ウインドウに他のタブがあるとき、次のタブを選択します。
win.showAllTabs() macOS
ネイティブのタブが有効な場合に、タブの概要を表示または非表示にします。
win.mergeAllWindows() macOS
ネイティブのタブが有効で複数の開いているウインドウがあるとき、すべてのウインドウを複数のタブで1つのウインドウにマージします。
win.moveTabToNewWindow() macOS
ネイティブのタブが有効で現在のウインドウに複数のタブがあるとき、現在のタブを新しいウインドウに移動します。
win.toggleTabBar() macOS
ネイティブのタブが有効で現在のウインドウにタブが1つだけしかないとき、タブバーを表示するかどうかを切り替えます。
win.addTabbedWindow(browserWindow) macOS
- browserWindowBrowserWindow
ウインドウインスタンスのタブの後ろに、このウインドウのタブとしてウインドウを追加します。
win.setVibrancy(type[, options]) macOS
- typestring | null -- titlebar,- selection,- menu,- popover,- sidebar,- header,- sheet,- window,- hud,- fullscreen-ui,- tooltip,- content,- under-window,- under-pageのいずれかにできます。 詳細は macOSのドキュメント をご参照ください。
ブラウザウィンドウにバイブレンシーエフェクトを追加します。 null または空の文字列を渡すと、ウィンドウのバイブレンシーエフェクトを削除します。 The animationDuration parameter only animates fading in or fading out the vibrancy effect. Animating between different types of vibrancy is not supported.
win.setBackgroundMaterial(material) Windows
- materialstring- auto- デスクトップウインドウマネージャ (DWM) に、このウインドウのシステム描画の背景マテリアルを自動決定させます。 これが既定値です。
- none- システムの背景を描画しません。
- mica- 長い間表示されるウインドウに対応する背景マテリアルの効果を描画します。
- acrylic- 一時的なウインドウに対応する背景マテリアルの効果を描画します。
- tabbed- タブ化したタイトルバー付きのウインドウに対応する背景マテリアルの効果を描画します。
 
このメソッドは、非クライアント領域の背後を含む、ブラウザウインドウのシステム描画の背景マテリアルを設定します。
See the Windows documentation for more details.
[!NOTE] This method is only supported on Windows 11 22H2 and up.
win.setWindowButtonPosition(position) macOS
- positionPoint | null
フレームレスウインドウにおける信号機ボタンのカスタム位置を設定します。 null を渡すと既定の位置へリセットします。
win.getWindowButtonPosition() macOS
戻り値 Point | null - フレームレスウインドウの信号機ボタンのカスタム位置。カスタム位置がない場合は null が返されます。
win.setTouchBar(touchBar) macOS
- touchBarTouchBar | null
現在のウインドウのTouchBarレイアウトを設定します。 null または undefined を指定すると、TouchBarがクリアされます。 このメソッドは TouchBar 搭載マシンでのみ作用します。
[!NOTE] The TouchBar API is currently experimental and may change or be removed in future Electron releases.
win.setBrowserView(browserView) 実験的 非推奨
- browserViewBrowserView | null - Attach- browserViewto- win. 他の- BrowserViewがアタッチされている場合、それはこのウィンドウから削除されます。
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.getBrowserView() 実験的 非推奨
戻り値 BrowserView | null - win にアタッチされた BrowserView。 アタッチされていない場合は null を返します。 複数の BrowserView がアタッチされている場合、エラーを送出します。
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.addBrowserView(browserView) 実験的 非推奨
- browserViewBrowserView
複数の BrowserView をサポートする setBrowserView の置換 API。
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.removeBrowserView(browserView) 実験的 非推奨
- browserViewBrowserView
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.setTopBrowserView(browserView) 実験的 非推奨
- browserViewBrowserView
browserView を win にアタッチされた他の BrowserView の上へと持ち上げます。 browserView が win にアタッチされていない場合, エラーを送出します。
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.getBrowserViews() 実験的 非推奨
戻り値 BrowserView[] - addBrowserView または setBrowserView でアタッチされ、z-index でソートされたたすべての BrowserView の配列。 最も上にある BrowserView は配列の最後の要素です。
[!WARNING] The
BrowserViewclass is deprecated, and replaced by the newWebContentsViewclass.
win.setTitleBarOverlay(options) Windows Linux
ウインドウコントロールオーバーレイがすでに有効になっているウインドウに対して、このメソッドはそのタイトルバーオーバーレイのスタイルを更新します。
Linux で color を明示的に設定していない場合、symbolColor は color に対して最小限のアクセシビリティがあるコントラストになるように自動計算されます。