如何从Electron上的preload脚本中的渲染过程访问jquery

问题描述 投票:0回答:1

我在窗口中将Node集成配置为false,因为如文档中所述,禁用是一种很好的做法。

我想在我的预加载脚本中访问我的渲染过程的jQuery,但我不知道如何做到这一点。

在预加载脚本中发生某些事件后,是否可以激活模态(例如)?

链接到我在Github中的示例代码:https://github.com/JhonatanRSantos/Sample

javascript node.js electron
1个回答
0
投票

正如Janith所说,您不需要使用预加载脚本。这是一个基于您的Github仓库的工作示例:

Index.html - 在HEADER部分,修改如下:

<script>window.$ = window.jQuery = require('jquery');</script>
<script src="./node_modules/popper.js/dist/umd/popper.min.js"></script>
<script src="./node_modules/bootstrap/dist/js/bootstrap.min.js"></script>

请注意,您必须使用路径./node_modules/popper.js/dist/umd/popper.min.js,否则您将在控制台中收到错误(请参阅popper.js in bootstrap 4 gives SyntaxError Unexpected token export

Index.html - FOOTER,添加:

<script src="./index.js"></script>

将preload.js重命名为index.js

index.js可以是:

console.log('Preload.js');
setTimeout(() => {
    console.log('Open Boostrap Modal');
    $('#myModal').modal('show');
}, 5000);

最后,main.js可以是:

const { app, BrowserWindow } = require('electron');
const path = require('path')
const url = require('url')

let createWindow = () => {
    let win = new BrowserWindow({
        width: 800,
        height: 500,
        center: true,
        resizable: false,
        show: false
    });
    win.setMenu(null);
    const mainUrl = url.format({ // https://electronjs.org/docs/api/browser-window#winloadurlurl-options
        protocol: 'file',
        slashes: true,
        pathname: path.join(__dirname, 'index.html')
      })
    win.loadURL(mainUrl);
    win.once('ready-to-show', () => {
        win.show();
        win.webContents.openDevTools();
    });
    win.on('closed', () => {
        win = null;
    });
};
app.on('ready', createWindow);

我向您的仓库发出拉动请求以获取更改。

© www.soinside.com 2019 - 2024. All rights reserved.