electron/docs/api/clipboard.md

150 lines
3.3 KiB
Markdown
Raw Normal View History

2013-09-09 07:35:57 +00:00
# clipboard
2013-08-14 22:43:35 +00:00
2016-04-21 22:39:12 +00:00
> Perform copy and paste operations on the system clipboard.
2015-08-25 12:16:20 +00:00
The following example shows how to write a string to the clipboard:
2013-08-14 22:43:35 +00:00
```javascript
const {clipboard} = require('electron')
clipboard.writeText('Example String')
2013-08-14 22:43:35 +00:00
```
On X Window systems, there is also a selection clipboard. To manipulate it
you need to pass `selection` to each method:
```javascript
const {clipboard} = require('electron')
clipboard.writeText('Example String', 'selection')
console.log(clipboard.readText('selection'))
```
2015-08-24 21:35:43 +00:00
## Methods
2015-08-26 23:28:44 +00:00
The `clipboard` module has the following methods:
2015-08-24 21:35:43 +00:00
2015-08-28 17:34:48 +00:00
**Note:** Experimental APIs are marked as such and could be removed in future.
2015-08-24 21:35:43 +00:00
### `clipboard.readText([type])`
* `type` String (optional)
2013-08-14 22:43:35 +00:00
Returns the content in the clipboard as plain text.
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
### `clipboard.writeText(text[, type])`
2013-08-14 22:43:35 +00:00
* `text` String
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2013-08-14 22:43:35 +00:00
Writes the `text` into the clipboard as plain text.
2013-08-14 22:43:35 +00:00
2016-05-26 21:26:12 +00:00
### `clipboard.readHTML([type])`
2015-08-24 21:35:43 +00:00
* `type` String (optional)
Returns the content in the clipboard as markup.
2016-05-26 21:26:12 +00:00
### `clipboard.writeHTML(markup[, type])`
* `markup` String
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2015-08-24 21:35:43 +00:00
Writes `markup` to the clipboard.
2015-08-24 21:35:43 +00:00
### `clipboard.readImage([type])`
2015-03-26 04:53:48 +00:00
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2015-03-26 04:53:48 +00:00
Returns the content in the clipboard as a [NativeImage](native-image.md).
2015-03-26 04:53:48 +00:00
2015-08-24 21:35:43 +00:00
### `clipboard.writeImage(image[, type])`
2015-03-26 04:53:48 +00:00
* `image` [NativeImage](native-image.md)
2015-08-24 21:35:43 +00:00
* `type` String (optional)
Writes `image` to the clipboard.
2015-03-26 04:53:48 +00:00
2016-05-26 21:26:12 +00:00
### `clipboard.readRTF([type])`
* `type` String (optional)
Returns the content in the clipboard as RTF.
2016-05-26 21:26:12 +00:00
### `clipboard.writeRTF(text[, type])`
* `text` String
* `type` String (optional)
Writes the `text` into the clipboard in RTF.
### `clipboard.readBookmark()` _macOS_ _Windows_
2016-06-24 22:20:49 +00:00
2016-06-24 22:35:30 +00:00
Returns an Object containing `title` and `url` keys representing the bookmark in
the clipboard. The `title` and `url` values will be empty strings when the
bookmark is unavailable.
2016-06-24 22:20:49 +00:00
### `clipboard.writeBookmark(title, url[, type])` _macOS_ _Windows_
2016-06-24 22:20:49 +00:00
* `title` String
* `url` String
* `type` String (optional)
Writes the `title` 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.write` to write both a bookmark and fallback text to the
clipboard.
```js
clipboard.write({
text: 'http://electron.atom.io',
bookmark: 'Electron Homepage'
})
```
2015-08-24 21:35:43 +00:00
### `clipboard.clear([type])`
2015-03-26 04:53:48 +00:00
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2015-08-24 21:35:43 +00:00
Clears the clipboard content.
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
### `clipboard.availableFormats([type])`
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
Returns an array of supported formats for the clipboard `type`.
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
### `clipboard.has(data[, type])` _Experimental_
2013-08-14 22:43:35 +00:00
2015-05-27 08:05:51 +00:00
* `data` String
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2013-08-14 22:43:35 +00:00
Returns whether the clipboard supports the format of specified `data`.
2015-05-27 08:05:51 +00:00
```javascript
const {clipboard} = require('electron')
console.log(clipboard.has('<p>selection</p>'))
2015-05-27 08:05:51 +00:00
```
2015-08-24 21:35:43 +00:00
### `clipboard.read(data[, type])` _Experimental_
2015-05-27 08:05:51 +00:00
* `data` String
2015-08-24 21:35:43 +00:00
* `type` String (optional)
2015-05-27 08:05:51 +00:00
Reads `data` from the clipboard.
2013-08-14 22:43:35 +00:00
2015-08-24 21:35:43 +00:00
### `clipboard.write(data[, type])`
* `data` Object
* `text` String
* `html` String
* `image` [NativeImage](native-image.md)
2016-06-24 22:16:05 +00:00
* `rtf` String
2016-06-24 22:20:49 +00:00
* `bookmark` String - The title of the url at `text`.
2015-08-24 21:35:43 +00:00
* `type` String (optional)
```javascript
const {clipboard} = require('electron')
clipboard.write({text: 'test', html: '<b>test</b>'})
```
2015-08-24 21:35:43 +00:00
Writes `data` to the clipboard.