- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
比如说,你有一些变量想要在 css 和 js 代码之间共享:
vars.js
:
module.exports = {
'body-margin': '100px',
};
样式.css
:
body {
margin: var(--body-margin);
}
entry.js
:
var vars = require('./vars.js');
require('./style.css');
document.body.appendChild(
document.createTextNode(vars['body-margin']));
我使用 postcss-cssnext
/postcss-custom-properties
插件来做到这一点:
webpack.config.js
:
var HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
entry: './entry.js',
output: {
filename: 'bundle.js',
},
module: {
rules: [{
test: /\.css$/,
use: [
'style-loader',
'css-loader',
{loader: 'postcss-loader',
options: {
plugins: [
require('postcss-cssnext')({
features: {
customProperties: {
variables: require('./vars.js'),
},
},
}),
],
}},
],
}],
},
plugins: [new HtmlWebpackPlugin()],
};
但是当我运行 webpack-dev-server
并更改 vars.js
中的变量时,javascript 代码会注意到更改,但 css 代码不会。有没有办法来解决这个问题?使 css 反射(reflect)更改而无需重新启动 webpack-dev-server
。附言我并没有死心塌地地使用 postcss
/cssnext
/postcss-custom-properties
来共享变量,如果有的话。
package.json
:
{
"dependencies": {
"css-loader": "^0.28.7",
"html-webpack-plugin": "^2.30.1",
"postcss-cssnext": "^3.0.2",
"postcss-loader": "^2.0.6",
"style-loader": "^0.18.2",
"webpack": "^3.6.0",
"webpack-dev-server": "^2.8.2"
}
}
最佳答案
我想出了以下方法来修复它:
diff --git a/webpack.config.js b/webpack.config.js
index 0046862..73c75a1 100644
--- a/webpack.config.js
+++ b/webpack.config.js
@@ -1,5 +1,20 @@
+var path = require('path');
var HtmlWebpackPlugin = require('html-webpack-plugin');
+var varsFile = './vars.js';
+
+var postcssCssnextFeatures = require('postcss-cssnext/lib/features').default;
+var customPropertiesPlugin;
+postcssCssnextFeatures.customProperties = (options) => {
+ customPropertiesPlugin = require('postcss-custom-properties')(options);
+ return customPropertiesPlugin;
+};
+
+function getVars() {
+ delete require.cache[require.resolve(varsFile)];
+ return require(varsFile);
+}
+
module.exports = {
entry: './entry.js',
output: {
@@ -17,7 +32,7 @@ module.exports = {
require('postcss-cssnext')({
features: {
customProperties: {
- variables: require('./vars.js'),
+ variables: getVars(),
},
},
}),
@@ -26,5 +41,22 @@ module.exports = {
],
}],
},
- plugins: [new HtmlWebpackPlugin()],
+ plugins: [
+ new HtmlWebpackPlugin(),
+ {apply: function(compiler) {
+ compiler.plugin('compilation', function(compilation) {
+ compilation.plugin('succeed-module', function(module) {
+ if (module.resource
+ && module.resource.indexOf(path.resolve('node_modules')) == -1
+ && path.extname(module.resource) == '.css'
+ && module.fileDependencies.indexOf(varsFile) == -1 // extract-text-webpack-plugin, for instance, makes webpack build modules twice
+ ) {
+ module.fileDependencies.push(varsFile);
+ }
+ });
+ });
+ compiler.plugin('invalid', function(filename) {
+ customPropertiesPlugin.setVariables(getVars());
+ });
+ }},
+ ],
};
我遇到的问题:
postcss-custom-properties
插件返回带有 setVariables
method 的对象,可用于更新变量。但是 postcss
/cssnext
没有提供 easy way访问该对象。所以我猴子修补 postcss-cssnext/lib/features.js
,拦截对象并放入 customPropertiesPlugin
变量。
我不能简单地要求 vars.js
。内容已缓存。
如果您知道任何更简单的方法,请告诉我,我将不胜感激。或者也许只是一个想法。或者改进我的解决方案的方法。理想情况下,我想必须有允许 @import
javascript 文件的 postcss
插件。
关于javascript - 如何告诉 webpack 额外的依赖?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46401773/
我配置了我的RouteInitializer如下: class AppRouteInitializer implements RouteInitializer { init(Router rout
我正在尝试从 Android 应用程序发送短信。我正在使用 PendingIntent 以便我可以使用 Broadcast Receiver 检查它是否发送正常。由于 sendTextMessage
目录 简介 1 "额外"字段是什么 1.1 "额外"是指与业务无关 1.2 产生
应用程序读取 JSON 数据。然后它会将其放入 ListView (正确),但在按下某个项目后,我总是会得到显示的相同值。下面的代码我认为是问题所在,但我找不到。 try{ JSONArray
我正在使用以下代码 (Kotlin) 创建通知 val builder = NotificationCompat.Builder(ctx) ........ .set
我有一个问题。现在我正在使用 3 个面板,mainPanel 和其他 2 个面板(btnPanel 和 iconPanel)。所以问题是当我按下“重置”按钮时,我删除了 iconPanel 并再次添加
这是我的 html: Settings Export Import 和CSS: span.button { float:right; margin-righ
我正在尝试将一个结构编码为 JSON,然后将其插入我的 Mongo 数据库,但不断出现此错误:%!(EXTRA main.Test={575590180 Me})。我究竟做错了什么?我完全从我从事的另
嘿,我遇到了这些 latex 格式问题,有人可以提供一些帮助吗? .tex 文件: \begin{table}{} \renewcommand{\arraystretch}{1.1} \c
我在 FragmentPagerAdapter 中使用了 Fragment 的 ArrayList。 我想在 saveState() 中保存此 ArrayList 的状态,并在 restoreStat
我做了this MapKit-教程 一切正常,但如何为我的 pin 添加额外的属性? 这是我的课车: import Foundation import MapKit class Car: NSObje
关于 Android intent 将提供的附加功能有哪些文档? 更新: 我做了一些进一步的调查。我知道我们可以假设每个 Intent 都不会解析任何数据或额外内容,除非有明确记录。此外,一些(但不是
我在 python3.4.3 上使用 SqlAlchemy 来管理 MySQL 数据库。我正在创建一个表: from datetime import datetime from sqlalchemy
我正在使用 bootstrap 创建网页。我在两个 block (内容和标题)上派生了正文。在内容 block 中,我有 div 类 .container .sameTable 在里面我有 div 类
我在Windows 7上的MinGW和MSYS下使用gfortran构建了一些fortran程序。但是当我在未安装MinGW和MSYS的其他计算机上运行它们时,系统总是要求一些dll,例如libgfo
第一个元素的右侧似乎有额外的间距,我不知道它是从哪里来的。有人可以帮助我吗? 这是我使用的代码: http://jsfiddle.net/srabeat/tenx4y1c/1/ for (i = 0;
我使用 fs-extra 收到以下错误: ERROR { [Error: EPERM: operation not permitted, unlink 'C:\Projects\xxx\branche
我正在尝试在 CBC 模式下使用 AES-128 加密 320 字节的二进制数据,并将密码存储到一个文件中。输出文件应该是 320 字节,但我得到了 336 字节。这是我的代码: #include
我有一个特定的要求,我必须从我的 Activity 中触发浏览器上的 url。我可以使用以下代码执行此操作: Intent browserIntent = new Intent( Intent.A
我正在使用 JMS DI 注入(inject)带有注解的服务: use JMS\DiExtraBundle\Annotation as DI; /** * @DI\Service("foo.bar.
我是一名优秀的程序员,十分优秀!