clipboard
Выполняет копирование и вставку в буфер обмена системы.
Process: Main, Renderer (non-sandboxed only)
[!IMPORTANT] If you want to call this API from a renderer process with context isolation enabled, place the API call in your preload script and expose it using the
contextBridgeAPI.
В Linux также есть selection буфер обмена. Для работы с ним необходимо передать selection каждому методу:
const { clipboard } = require('electron')
clipboard.writeText('Example string', 'selection')
console.log(clipboard.readText('selection'))
Методы
Модуль clipboard имеет следующие методы:
[!NOTE] Experimental APIs are marked as such and could be removed in future.
clipboard.readText([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Возвращает string — содержимое в буфере обмена в виде обычного текста.
const { clipboard } = require('electron')
clipboard.writeText('hello i am a bit of text!')
const text = clipboard.readText()
console.log(text)
// hello i am a bit of text!'
clipboard.writeText(text[, type])
textstringtypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает text в буфер обмена как обычный текст.
const { clipboard } = require('electron')
const text = 'hello i am a bit of text!'
clipboard.writeText(text)
clipboard.readHTML([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Возвращает string - содержимое в буфере обмена в виде разметки.
const { clipboard } = require('electron')
clipboard.writeHTML('<b>Hi</b>')
const html = clipboard.readHTML()
console.log(html)
// <meta charset='utf-8'><b>Hi</b>
clipboard.writeHTML(markup[, type])
markupstringtypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает markup в буфер обмена.
const { clipboard } = require('electron')
clipboard.writeHTML('<b>Hi</b>')
clipboard.readImage([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Returns NativeImage - The image content in the clipboard.
clipboard.writeImage(image[, type])
imageNativeImagetypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает image в буфер обмена.
clipboard.readRTF([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Возвращает string - содержимое в буфере обмена в виде RTF.
const { clipboard } = require('electron')
clipboard.writeRTF('{\\rtf1\\ansi{\\fonttbl\\f0\\fswiss Helvetica;}\\f0\\pard\nThis is some {\\b bold} text.\\par\n}')
const rtf = clipboard.readRTF()
console.log(rtf)
// {\\rtf1\\ansi{\\fonttbl\\f0\\fswiss Helvetica;}\\f0\\pard\nThis is some {\\b bold} text.\\par\n}
clipboard.writeRTF(text[, type])
textstringtypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает text в буфер обмена как RTF.
const { clipboard } = require('electron')
const rtf = '{\\rtf1\\ansi{\\fonttbl\\f0\\fswiss Helvetica;}\\f0\\pard\nThis is some {\\b bold} text.\\par\n}'
clipboard.writeRTF(rtf)
clipboard.readBookmark() macOS Windows
Возвращает Object:
titlestringurlstring
Возвращает объект, содержащий ключи title и url, представляющие закладку в буфере обмена. Значения title и url будут пустыми строками, когда закладки недоступны. The title value will always be empty on Windows.
clipboard.writeBookmark(title, url[, type]) macOS Windows
titlestring - Unused on Windowsurlstringtypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Writes the title (macOS only) and url into the clipboard as a bookmark.
[!NOTE] Most apps on Windows don't support pasting bookmarks into them so you can use
clipboard.writeto write both a bookmark and fallback text to the clipboard.
const { clipboard } = require('electron')
clipboard.writeBookmark('Electron Homepage', 'https://electronjs.org')
clipboard.readFindText() macOS
Возвращает string - текст в панели поиска, который представляет собой информацию о текущем состоянии панели поиска активного приложения.
Этот метод использует синхронный IPC, когда вызывается в процессе рендеринга. Закэшированное значение перечитывается из буфера обмена, всякий раз, когда приложение активировано.
clipboard.writeFindText(text) macOS
textstring
Записывает text в панель поиска (панель, которая содержит информацию о текущем состоянии панели поиска активного приложения) в виде простого текста. Этот метод использует синхронный IPC, когда вызывается в процессе рендеринга.
clipboard.clear([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Очищает содержимое буфера обмена.
clipboard.availableFormats([type])
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Возвращает string[] - массив поддерживаемых форматов для type буфера обмена.
const { clipboard } = require('electron')
const formats = clipboard.availableFormats()
console.log(formats)
// [ 'text/plain', 'text/html' ]
clipboard.has(format[, type]) Экспериментально
formatstringtypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Возвращает boolean - поддерживает ли буфер обмена указанный format.
const { clipboard } = require('electron')
const hasFormat = clipboard.has('public/utf8-plain-text')
console.log(hasFormat)
// 'true' or 'false'
clipboard.read(format) Экспериментально
formatstring
Возвращает string - читает тип format из буфера обмена.
format should contain valid ASCII characters and have / separator. a/c, a/bc are valid formats while /abc, abc/, a/, /a, a are not valid.
clipboard.readBuffer(format) Экспериментально
formatstring
Возвращает Buffer - читает тип format из буфера обмена.
const { clipboard } = require('electron')
const buffer = Buffer.from('this is binary', 'utf8')
clipboard.writeBuffer('public/utf8-plain-text', buffer)
const ret = clipboard.readBuffer('public/utf8-plain-text')
console.log(buffer.equals(ret))
// true
clipboard.writeBuffer(format, buffer[, type]) Экспериментально
formatstringbufferBuffertypestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает buffer в буфер обмена, как format.
const { clipboard } = require('electron')
const buffer = Buffer.from('writeBuffer', 'utf8')
clipboard.writeBuffer('public/utf8-plain-text', buffer)
clipboard.write(data[, type])
dataObjecttextstring (опционально)htmlstring (опционально)imageNativeImage (optional)rtfstring (опционально)bookmarkstring (опционально) - заголовок ссылки наtext.
typestring (опционально) - Может бытьselectionилиclipboard; по умолчанию 'clipboard'.selectionдоступен только в Linux.
Записывает data в буфер обмена.
const { clipboard } = require('electron')
clipboard.write({
text: 'test',
html: '<b>Hi</b>',
rtf: '{\\rtf1\\utf8 text}',
bookmark: 'a title'
})
console.log(clipboard.readText())
// 'test'
console.log(clipboard.readHTML())
// <meta charset='utf-8'><b>Hi</b>
console.log(clipboard.readRTF())
// '{\\rtf1\\utf8 text}'
console.log(clipboard.readBookmark())
// { title: 'a title', url: 'test' }