2015-05-18 14 views
11

Sono ancora nuovo in Electron che attualmente sto seguendo here.Come includere Chrome DevTools in Electron?

Ho letto questo page su come includere lo Chrome DevTools in modo che possa eseguire facilmente il debug dell'applicazione. Ho seguito la documentazione ma una volta che esegue il comando electron <app-name> restituisce un errore: The app provided is not a valid electron app, please read the docs on how to write one...

Ecco il blocco di codice dal mio main.js lima:

var app = require('app'); 
var BrowserWindow = require('browser-window'); 

// Add Chrome DevTools extension for debugging 
require('remote').require('browser-window').addDevToolsExtension('../react-devtools') 

Questo è come la mia struttura del progetto si presenta come:

- react-devtools 
- src 
    -- index.html 
    -- main.js 
- package.json 

Qualsiasi aiuto sarebbe molto apprezzato. Grazie!

+0

So che questa domanda è orientata verso il motivo per cui questo errore viene visualizzato, e non sono sicuro se questo differisce dall'estensione degli strumenti di sviluppo, ma prova a chiamare il metodo .openDevTools() sull'oggetto BrowserWindow che hai creato e vedere se ti dà il desiderio che stai cercando. –

risposta

0

Molto probabilmente, Electron non è in grado di capire il percorso della cartella dell'applicazione che hai fornito. È necessario fornire il percorso relativo o assoluto alla directory dell'applicazione che contiene package.json in esso. Per esempio, se il file package.json della vostra applicazione si trova a /home/user/my_awesome_app/package.json poi, al fine di avviare l'applicazione è necessario eseguire il seguente comando:

electron /home/user/my_awesome_app 

Si noti inoltre che main proprietà in package.json file indica il punto di ingresso per l'applicazione. Nel tuo caso deve essere in questo modo:

"main": "src/main.js" 
+0

Sì, ho già fatto quella parte, sono riuscito a far funzionare bene la mia app. Il problema si verifica solo quando provo ad aggiungere 'react-devtools' per scopi di debug. Questo è quando l'errore si apre. – Renesansz

+0

Che tipo di errore si ottiene quando si chiama 'addDevToolsExtension'? –

+0

'L'app fornita non è un'app elettrone valida, per favore leggi i documenti su come scrivere uno..blabla' appare quando aggiungo la riga' require ('remote'). Require ('browser-window'). AddDevToolsExtension ('../ react-devtools') ' È possibile fare riferimento alla struttura del progetto sopra riportata per riferimento. – Renesansz

0

Il nome del aplication è il nome della cartella che contiene tutto l'albero della vostra aplication. Quindi per eseguire devi scrivere, nel caso in cui la tua cartella si chiami Electron per esempio;

elettrone Electron

sempre in pronta nel percorso che la cartella si trova. Spero che questo aiuto.

(Ci scusiamo per il mio inglese, po 'arrugginito forse)

9

Così, dopo aver richiesto il seguente:

var app = require('app'); 

È possibile utilizzare il seguente codice (lo uso nel mio app):

app.commandLine.appendSwitch('remote-debugging-port', '8315'); 
app.commandLine.appendSwitch('host-rules', 'MAP * 127.0.0.1'); 

accedendo al seguente indirizzo mi permette di eseguire il debug dell'applicazione in Chrome:

http://127.0.0.1:8315 

Spero che questo ti aiuti. Sono anche nuovo di Electron!

Se è anche necessario eseguire alcune configurazioni sul motore del browser sottostante, fare riferimento a the docs.

+0

Questo è esattamente quello che stavo cercando! – Daantje

2

Forse sto fraintendendo, ma puoi semplicemente fare CTRL + MAIUSC + I per visualizzare gli strumenti di sviluppo.

In alternativa, se si desidera eseguirlo a livello di codice, il modo in cui lo faccio è includere le seguenti righe nel mio file main.js che viene passato a electron.

var app = require('app'); 
var BrowserWindows = require('browser-window'); 

app.on('ready', function(){ 
    mainWindow = new BrowserWindow({width:800, height:600}); 
    mainWindow.webContents.openDevTools(); 
} 

credo che parte del problema potrebbe essere che non è in attesa per l'applicazione sia pronta prima di provare a fare cose con esso.

1

è possibile aprire strumento dev come questo:

mainWindow = new BrowserWindow({ width: 1024, height: 768 }); 
mainWindow.loadURL('your url'); 
mainWindow.webContents.openDevTools(); 
mainWindow.webContents.on('devtools-opened',() => { 
    setImmediate(() => { 
     // do whatever you want to do after dev tool completely opened here 
     mainWindow.focus(); 
    }); 
}); 
0

Aprite la vostra applicazione di elettroni, fare clic su (vista/commutazione strumenti di sviluppo).