docs: revised the drag and drop feature page (#25939)
* docs: revised the drag and drop feature page * docs: fixed mentions in the drag and drop feature page * docs: fixed mentions in the drag and drop feature page
This commit is contained in:
parent
46f3491c7d
commit
55fdc1795c
2 changed files with 33 additions and 12 deletions
BIN
docs/images/drag-and-drop.gif
Normal file
BIN
docs/images/drag-and-drop.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.2 MiB |
|
@ -1,29 +1,44 @@
|
||||||
# Native File Drag & Drop
|
# Native File Drag & Drop
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
Certain kinds of applications that manipulate files might want to support
|
Certain kinds of applications that manipulate files might want to support
|
||||||
the operating system's native file drag & drop feature. Dragging files into
|
the operating system's native file drag & drop feature. Dragging files into
|
||||||
web content is common and supported by many websites. Electron additionally
|
web content is common and supported by many websites. Electron additionally
|
||||||
supports dragging files and content out from web content into the operating
|
supports dragging files and content out from web content into the operating
|
||||||
system's world.
|
system's world.
|
||||||
|
|
||||||
To implement this feature in your app, you need to call `webContents.startDrag(item)`
|
To implement this feature in your app, you need to call the
|
||||||
|
[`webContents.startDrag(item)`](../api/web-contents.md#contentsstartdragitem)
|
||||||
API in response to the `ondragstart` event.
|
API in response to the `ondragstart` event.
|
||||||
|
|
||||||
In your renderer process, handle the `ondragstart` event and forward the
|
## Example
|
||||||
information to your main process.
|
|
||||||
|
Starting with a working application from the
|
||||||
|
[Quick Start Guide](quick-start.md), add the following lines to the
|
||||||
|
`index.html` file:
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<a href="#" id="drag">item</a>
|
<a href="#" id="drag">Drag me</a>
|
||||||
<script type="text/javascript" charset="utf-8">
|
<script src="renderer.js"></script>
|
||||||
document.getElementById('drag').ondragstart = (event) => {
|
|
||||||
event.preventDefault()
|
|
||||||
ipcRenderer.send('ondragstart', '/path/to/item')
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Then, in the main process, augment the event with a path to the file that is
|
and add the following lines to the `renderer.js` file:
|
||||||
being dragged and an icon.
|
|
||||||
|
```js
|
||||||
|
const { ipcRenderer } = require('electron')
|
||||||
|
|
||||||
|
document.getElementById('drag').ondragstart = (event) => {
|
||||||
|
event.preventDefault()
|
||||||
|
ipcRenderer.send('ondragstart', '/absolute/path/to/the/item')
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
The code above instructs the Renderer process to handle the `ondragstart` event
|
||||||
|
and forward the information to the Main process.
|
||||||
|
|
||||||
|
In the Main process(`main.js` file), expand the received event with a path to the file that is
|
||||||
|
being dragged and an icon:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
const { ipcMain } = require('electron')
|
const { ipcMain } = require('electron')
|
||||||
|
@ -35,3 +50,9 @@ ipcMain.on('ondragstart', (event, filePath) => {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
|
||||||
|
After launching the Electron application, try to dragging and dropping
|
||||||
|
the item from the BroswerWindow onto your desktop. In this guide,
|
||||||
|
the item is a Markdown file located in the root of the project:
|
||||||
|
|
||||||
|
![Drag and drop](../images/drag-and-drop.gif)
|
||||||
|
|
Loading…
Reference in a new issue