我正在使用一个同构的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 – Webpack SCSS“Flicker”在页面加载之前的更多相关文章

  1. 有没有办法知道购买哪个iTunes帐户? – iOS

    我的应用程序提供应用内购买非消耗类型.该应用程序具有登录功能.是否可以根据登录用户购买我的应用程序?

  2. ios – Apple应用程序内购买收据 – 在服务器端验证

    我想验证它,并确保这是独一无二的.我担心的是:如果有人会收到一张有效收据,他就可以破解我们的服务器端API,并使用相同的有效收据进行无限数量的应用内购买.我应该以某种方式解密并检查transaction_id的“原始”收据,即我发送给Apple进行验证的收据?

  3. ios – 服务器端接收验证失败时是否应该调用finishTransaction?

    我们应该调用finishTransaction吗?这导致无效的交易永远活在队列中?就像在这个问题上说的那样:iPhonein-apppurchase:receiptverificationButifyoufindoutthatareceiptisinvalid,youshouldfinishtheassociatedtransaction.Ifnot,youmayhaveextra-transactionslivingforeverinthetransactionqueue.Thatmeansthatea

  4. Project Perfect让Swift在服务器端跑起来-引言一

    你认识Swift或者是在客户端,因为它是苹果用来开发客户端的新一代语言。可以说Swift已经是一个完整的跨平台语言了。Perfect让Swift在服务器端跑起来了,它是开源的。添加完后你打开Xcode就可以看到Perfect模版了。PerfectLib你可以理解成Perfect框架,而PerfectServer是启动支持Perfect的类似IIS/Apache的容器,MysqL是需要介入MysqLConnector5.利用Perfect模版创建PerfectWeb项目,如图我创建了一个HelloWorld

  5. 详解如何使用webpack+es6开发angular1.x

    本篇文章主要介绍了详解如何使用webpack+es6开发angular1.x,具有一定的参考价值,有兴趣的可以了解一下

  6. JavaScript中Webpack的使用教程

    Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源,这篇文章主要介绍了JavaScript中Webpack的使用,需要的朋友可以参考下

  7. React+Webpack快速上手指南(小结)

    这篇文章主要介绍了React+Webpack快速上手指南(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. 详解Webpack+Babel+React开发环境的搭建的方法步骤

    本篇文章主要介绍了详解Webpack+Babel+React开发环境的搭建的方法步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. 详解基于webpack搭建react运行环境

    本篇文章主要介绍了详解基于webpack搭建react运行环境,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. Angular中支持SCSS的方法

    这篇文章主要介绍了Angular中支持SCSS的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部