防止页面加载电子之间出现白色闪烁

时间:2017-02-04 02:42:05

标签: javascript html css node.js electron

每次窗口开始加载新的html或向服务器发出make请求时,Window将变为白色,直到页面加载完毕或服务器已响应请求。这看起来并不好看,可能会非常刺耳。 我怎么能阻止这个?

代码如果你想看到它的话app.js

const {app, BrowserWindow} = require('electron');
const path = require('path');
const url = require('url');
let win;
function createWindow () {
    // Create the browser window.
    win = new BrowserWindow({width: 800, height: 600});
    win.loadURL(url.format({
        pathname: path.join(__dirname, 'index.html'),
        protocol: 'file:',
        slashes: true
    }));

    win.on('closed', () => {
        win = null;
})
}
app.on('ready', createWindow);
app.on('window-all-closed', () => {

    if (process.platform !== 'darwin') {
    app.quit();
}
});

app.on('activate', () => {

    if (win === null) {
    createWindow()
}
});

inedx.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
</head>
<body style="background-color: #222222">
<a href="index.html" style="color: white">Click on me to see a flash</a>
</body>
</html>

1 个答案:

答案 0 :(得分:3)

据我所见(例如:4 must-know tips for building cross platform Electron apps),设置窗口的背景颜色是至少减轻&#34; flash&#34;的典型方法。也许你可以想象CSS转换在加载前淡出窗口内容,然后在新内容加载后淡出它?

从该网站:

  

2.1指定BrowserWindow背景颜色如果您的应用程序具有非白色背景颜色,请务必在您的应用程序中指定它   BrowserWindow选项。这不会阻止纯色方块   当你的应用程序加载时,但至少它也没有改变   颜色中途:

mainWindow = new BrowserWindow({
    title: 'ElectronApp',
    backgroundColor: '#002b36',
  };
  

2.2隐藏您的应用程序,直到您的页面加载:因为我们实际上在浏览器中,我们可以选择隐藏窗口,直到我们   知道我们所有的资源都已加载。一旦开始,请确保   隐藏浏览器窗口:

var mainWindow = new BrowserWindow({
      title: 'ElectronApp',
      show: false,
  };
  

然后,当所有内容都加载完毕后,显示窗口并将其对焦   弹出用户。您可以使用&#34; ready-to-show&#34;事件   在您建议的BrowserWindow上,或者   &#39;做精加工负荷&#39; webContents上的活动。

mainWindow.on('ready-to-show', function() {
      mainWindow.show();
      mainWindow.focus();
  });