admin管理员组文章数量:1345290
I'm trying to read JSON from a file using the fs
module, and display that in a div
with id list
in an Electron app. My code in index.js
looks like this:
dialog.showOpenDialog((filenames) => {
if (!filenames) return;
fs.readFile(filenames[0], (err, data) => {
if (err) {
alert('Could not read file.\n\nDetails:\n' + err.message);
return;
}
let json = JSON.parse(data).en;
for (let i = 0; i < json.length; ++i) {
let html = "<div class='entry'><b>";
// Add more to html variable from json data
$('list').html(html);
}
});
});
I get an error saying:
Uncaught Exception:
Error: jQuery requires a window with a document
How do I modify the DOM from the JS, and why do I get this error?
I'm trying to read JSON from a file using the fs
module, and display that in a div
with id list
in an Electron app. My code in index.js
looks like this:
dialog.showOpenDialog((filenames) => {
if (!filenames) return;
fs.readFile(filenames[0], (err, data) => {
if (err) {
alert('Could not read file.\n\nDetails:\n' + err.message);
return;
}
let json = JSON.parse(data).en;
for (let i = 0; i < json.length; ++i) {
let html = "<div class='entry'><b>";
// Add more to html variable from json data
$('list').html(html);
}
});
});
I get an error saying:
Uncaught Exception:
Error: jQuery requires a window with a document
How do I modify the DOM from the JS, and why do I get this error?
Share Improve this question edited Jun 20, 2020 at 9:12 CommunityBot 11 silver badge asked Jun 9, 2017 at 10:24 RahulRahul 1,2562 gold badges12 silver badges27 bronze badges 3-
1
it may be relevant: stackoverflow./questions/32780726/…
webContents.executeJavaScript
can be used for such purposes – pergy Commented Jun 9, 2017 at 12:10 - I did see the answer suggesting that, but I was hoping that would be a last resort and that there would be something better. It really should be easier to do this, though. – Rahul Commented Jun 9, 2017 at 12:32
- the second answer suggests it, not the accepted one. For more plex things you'd better go with ipc munication though – pergy Commented Jun 9, 2017 at 12:47
2 Answers
Reset to default 8You can use executeJavascript
method of your BrowserWindow's webContents to execute code directly in Renderer process.
const { app, BrowserWindow} = require('electron')
const path = require('path')
const fs = require('fs')
app.once('ready', () => {
var mainWindow = new BrowserWindow()
mainWindow.loadURL(path.join(__dirname, 'index.html'))
fs.readFile(path.join(__dirname, 'test.json'), 'utf8', (err, data) => {
if (err) {
alert('Could not read file.\n\nDetails:\n' + err.message)
return
}
let json = JSON.parse(data)
for (let i in json) {
mainWindow.webContents.executeJavaScript(`
document.getElementById("list").innerHTML += '<br> ${i}: ${json[i]}'
`)
// can be replaced with
// $('#list').append('<br> ${i}: ${json[i]}')
// if html have jquery support
}
})
})
For using jquery in electron you should install jquery
module and refer it in your HTML
<script>window.$ = window.jQuery = require('jquery');</script>
Instructions in detail can be found here
you can try this
window.$ = require('jquery')(window);
it corrects this error for me
本文标签: javascriptdocument is not defined ElectronStack Overflow
版权声明:本文标题:javascript - `document` is not defined Electron - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743765470a2535152.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论