electron/docs-translations/it-IT/faq.md
2016-09-22 21:07:13 +02:00

167 lines
5.4 KiB
Markdown

# Electron FAQ
## Quando verrà utilizzata l'ultima versione di Chrome per Electron?
La versione di Chrome usata da Electron viene aggiornata solitamente entro una o
due settimane dal rilascio di una versione stabile di Chrome. Questa stima non è
garantita e dipende dall'ammontare di lavoro necessario all'aggiornamento.
E' utilizzato solo il canale stabile di Chrome. Se un fix importante si trovasse
sui canali beta o dev, lo applicheremo a una versione precedente.
Per maggiori informazioni, leggi l'[introduzione alla sicurezza](tutorial/sicurezza.md).
## Quando verrà utilizzata l'ultima versione di Node.js per Electron?
Quando una nuova versione di Node.js viene rilasciata, aspettiamo per circa un
mese prima di aggiornare quella di Electron. Possiamo così evitare di essere
influenzati dai bug introdotti nelle nuove versioni di Node.js, cosa che accade
spesso.
Le nuove funzionalità di Node.js sono solitamente introdotte dagli aggiornamenti
di V8. Siccome Electron usa la versione di V8 integrata nel browser Chrome, le
nuove funzionalità di JavaScript implementate nella nuova versione di Node.js
sono già presenti in Electron.
## Come condividere dati tra pagine web?
Il modo più semplice per condividere dati tra pagine web (il processo di
rendering) è usare le API di HTML5 già disponibili nei browser. Alcune buone
opzioni sono [Storage API][storage], [`localStorage`][local-storage],
[`sessionStorage`][session-storage] e [IndexDB][indexed-db].
Oppure puoi usare il sistema IPC, che è specifico di Electron, per memorizzare
gli oggetti nel processo principale come variabile globale e accedervi poi
dai renderer tramite la proprietà `remote` del modulo `electron`:
```javascript
// Nel processo principale.
global.sharedObject = {
someProperty: 'valore di default'
}
```
```javascript
// Nella pagina 1.
require('electron').remote.getGlobal('sharedObject').someProperty = 'nuovo valore'
```
```javascript
// Nella pagina 2.
console.log(require('electron').remote.getGlobal('sharedObject').someProperty)
```
## La finestra/icona della mia app è sparita dopo qualche minuto.
Ciò accade quando una variabile usata per la memorizzazione della finestra/
icona viene garbage-collected.
Se dovessi incontrare questo problema, i seguenti articoli potrebbero esserti
d'aiuto:
* [Gestione Memoria][memory-management]
* [Visibilità Variabili][variable-scope]
Se hai bisogno di un fix veloce, puoi rendere le variabili globali cambiando il
tuo codice da così:
```javascript
const {app, Tray} = require('electron')
app.on('ready', () => {
const tray = new Tray('/percorso/icona.png')
tray.setTitle('ciao mondo')
})
```
a così:
```javascript
const {app, Tray} = require('electron')
let tray = null
app.on('ready', () => {
tray = new Tray('/percorso/icona.png')
tray.setTitle('ciao mondo')
})
```
## Non posso usare jQuery/RequireJS/Meteor/AngularJS in Electron.
Data l'integrazione di Node.js di Electron, vi sono alcuni simboli extra
inseriti nel DOM quali `module`, `exports`, `require`. Ciò causa problemi ad
alcune librerie in quanto vogliono inserire simboli con gli stessi nomi.
Per risolvere il problema, puoi disattivare l'integrazione di Node in Electron:
```javascript
// Nel processo principale.
const {BrowserWindow} = require('electron')
let win = new BrowserWindow({
webPreferences: {
nodeIntegration: false
}
})
win.show()
```
Se invece volessi mantenere la capacità di usare Node.js e le API di Electron,
devi rinominare i simboli nella pagina prima di includere altre librerie:
```html
<head>
<script>
window.nodeRequire = require;
delete window.require;
delete window.exports;
delete window.module;
</script>
<script type="text/javascript" src="jquery.js"></script>
</head>
```
## `require('electron').xxx` is undefined.
Mentre usi il modulo integrato di Electron potresti incorrere in un errore
come questo:
```
> require('electron').webFrame.setZoomFactor(1.0)
Uncaught TypeError: Cannot read property 'setZoomLevel' of undefined
```
Ciò è causato dal fatto che hai il [modulo npm `electron`][electron-module]
installato localmente o globalmente, e ciò sovrascrive il modulo integrato di
Electron.
Per verificare che tu stia usando il modulo integrato corretto, puoi stampare a
schermo il percorso del modulo `electron`:
```javascript
console.log(require.resolve('electron'))
```
e dopodiché controlla che sia in questa forma
```
"/percorso/Electron.app/Contents/Resources/atom.asar/renderer/api/lib/exports/electron.js"
```
Se dovesse essere simile a `node_modules/electron/index.js`, allora devi
rimuovere il modulo npm `electron` oppure rinominarlo.
```bash
npm uninstall electron
npm uninstall -g electron
```
Tuttavia, se usi il modulo integrato e continui a ricevere questo errore è molto
probabile che tu stia usando il modulo in un processo sbagliato. Per esempio
`electron.app` può essere usato solo nel processo principale, mentre
`electron.webFrame` è disponibile solo nel processo di rendering.
[memory-management]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Memory_Management
[variable-scope]: https://msdn.microsoft.com/library/bzt2dkta(v=vs.94).aspx
[electron-module]: https://www.npmjs.com/package/electron
[storage]: https://developer.mozilla.org/en-US/docs/Web/API/Storage
[local-storage]: https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage
[session-storage]: https://developer.mozilla.org/en-US/docs/Web/API/Window/sessionStorage
[indexed-db]: https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API