我正在尝试使用purify-css for WebPack 从我的应用程序中删除未使用的 css 类。
为了构建这个项目,我正在使用React
, scss
,WebPack
并PostCss
构建和编译所有内容。
到目前为止,我能够取得进展,但有一些问题,我不知道为什么,但预期的结果不正确。我有一个非常基本的设置来测试这些场景,所以这是我的 index.html 和 app.js 文件(我目前仅有的文件):
索引.html
<body>
<nav>
<a href="">home</a>
</nav>
<hr />
<div id="app"></div>
<footer class="my-other-heading"></footer>
</body>
应用程序.js
class App extends React.Component {
render() {
return (
<h1 className="my-other-heading">Mamamia!</h1>
);
}
}
render(<App />, window.document.getElementById("app"));
在 css 文件中,我使用的是Normalize.css(带有一堆 css 类)和只有 3 个自定义类:
.my-class {
background-color: #CCDDEE;
}
.my-heading {
color: red;
}
.my-other-heading {
color: blue;
}
预期的输出应该只包含这些类:
html, body, nav, a, hr, div, footer, h1, .my-other-heading
但是它还有其他一些类:
.my-heading, h2, h3, h4, [type='checkbox'] (and other similar, e.g.: [type='button']
为什么会这样?它几乎删除了所有它应该删除的类,但其中一些仍然存在,并且显然没有在索引文件中使用的类。我不知道它们是否因为 React 方面的其他声明而持续存在,但我仅引用 src 文件。这是我的 purify-css 配置:
new PurifyCSSPlugin({
paths: glob.sync([
path.join(__dirname, '..', 'src', '**/*.html'),
path.join(__dirname, '..', 'src', '**/*.js'),
]),
})