JavaScript – Webpack SCSS“Flicker”在页面加载之前

前端之家收集整理的这篇文章主要介绍了JavaScript – Webpack SCSS“Flicker”在页面加载之前前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用一个同构的React Flux Express应用程序,并使用webpack加载器为我的sass(使用sass-loader)和jsx文件.我不知道如何将样式表注入服务器端模板.我为此目的看了Extract Text Plugin,但我真的希望能够使用热模块更换.
现在,我正在加载我的main.scss文件在一个React组件,如下所示:
if (typeof window !== 'undefined') {
  require("!style!css!sass!../../../styles/main.scss");
}

这对于在组件中加载单个样式表非常有用,但是在安装React部件之前有一个闪烁.我明白这是因为这是在客户端应用程序加载后注入样式表,因此样式表不能立即可用.
这导致了一个实际的问题:是否有一种方法可以将这个样式表注入到我的服务器端模板中,同时仍然使用webpack加载器,或者是否这样调用一个单独的gulpfile或express中间件?我以前使用gulpfile来构建我的样式表,但是最终会有很多样式表,并且不希望它们被卡在一个文件中.

解决方法

所以这里的想法是将webpack编译成两个独立的配置,一个针对web(浏览器),另一个针对节点(服务器端).可以在其他节点/ express代码中使用服务器端捆绑包来构建带有css的预渲染HTML.

这里有一个完整的例子,我将引导您完成相关部分.
https://github.com/webpack/react-starter

应用程序中的prerender.html是作者正在使用的服务器端模板.请注意以下两行代码

<link rel="stylesheet" href="STYLE_URL">
<script src="SCRIPT_URL"></script>

请参阅这里的webpack的配置https://github.com/webpack/react-starter/blob/master/make-webpack-config.js.传递到这里的选项取决于您是在做一个prod build还是dev build.由于我们要构建客户端软件包和预渲染服务器软件包,我们来看看https://github.com/webpack/react-starter/blob/master/webpack-production.config.js.它创建了两个软件包,特别是第一个软件包,针对浏览器设置了单独的样式表,第二个配置是用于预渲染的.

对于第一个编译,它使用:

plugins.push(new ExtractTextPlugin("[name].css" + (options.longTermCaching ? "?[contenthash]" : "")));

在您的捆绑包旁边创建一个单独的css文件.在第二次编译期间(用于预渲染),它使用null加载器来加载样式(因为我们已经有了我们在css文件中需要的样式,我们可以使用它).

现在这里我们将css的路径注入到服务器模板中.
看一下这个简化的server.js:https://github.com/webpack/react-starter/blob/8e6971d8fc9d18eeef7818bd6e9be45f6b8643e6/lib/server.js

var STYLE_URL = "main.css?" + stats.hash;
var SCRIPT_URL = [].concat(stats.assetsByChunkName.main)[0];
app.get("/*",function(req,res) {
    res.contentType = "text/html; charset=utf8";
    res.end(prerenderApplication(SCRIPT_URL,STYLE_URL,COMMONS_URL));
});

假设您的bundle的输出路径与server.js相同(否则可以使用require(“../ build / stats.json”)获取publicPath,并将其添加到上面的STYLE_URL和SCRIPT_URL中.

然后在你的prerender.jsx:https://github.com/webpack/react-starter/blob/8e6971d8fc9d18eeef7818bd6e9be45f6b8643e6/config/prerender.jsx
抓住您的服务器端模板prerender.html并替换URL:

var html = require("../app/prerender.html");
module.exports = function(scriptUrl,styleUrl,commonsUrl) {
    var application = React.renderComponentToString(<Application />);
    return html.replace("STYLE_URL",styleUrl).replace("SCRIPT_URL",scriptUrl).replace("COMMONS_URL",commonsUrl).replace("CONTENT",application);
};

我承认这可能是复杂和混乱的,如果使用单独的gulpfile更容易去.但是要做到这一点.如果您需要更多的澄清和帮助,您可以发表评论,我会尽快得到它,或者您可以使用webpack聊天室(https://gitter.im/webpack/webpack),我确定其中一个开发人员可能会给你比我做的更好的解释

希望这有点(?)的帮助!

猜你在找的JavaScript相关文章