reactjs – 用React和Webpack删除未使用的css

我正在尝试使用 purify-css for WebPack从我的应用程序中删除未使用的css类.

为了构建这个项目,我在React,scss,WebPack和PostCss中使用它来构建和编译所有东西.

到目前为止,我已经取得了进展,但有一些问题,我不知道为什么,但预期结果不正确.我有一个非常非常基本的设置来测试这些场景,所以这是我的index.html和app.js文件(到目前为止我唯一的文件):

的index.html

<body>
    <nav>
        <a href="">home</a>
    </nav>
    <hr />
    <div id="app"></div>
    <footer class="my-other-heading"></footer>
</body>

app.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 classess)和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,'**/*.js'),]),})
您可以尝试这个webpack.config示例,它从CSS和SASS文件删除所有未使用的类,但是,它添加了来自normalize.css的类
module: {
    rules: [
      {
        test: /\.css$/,use: ExtractTextPlugin.extract({
          fallback: 'style-loader',use: 'css-loader',publicPath: '/dist'
        })
      },{
        test: /\.scss$/,use: ['css-loader','sass-loader'],...
  plugins: [
    new HtmlWebpackPlugin({
      title: 'Webpack2 - purify css',minify: {
        collapseWhitespace: true,},hash: true,template: './src/index.html'
    }),new ExtractTextPlugin({
      filename: '[name].css',disable: false,allChunks: true
    }),new purifycssPlugin({
      paths: glob.sync(path.join(__dirname,'src/*.html')),purifyOptions: { info: true,minify: false }
    }),...

相关文章

一、前言 在组件方面react和Vue一样的,核心思想玩的就是组件...
前言: 前段时间学习完react后,刚好就接到公司一个react项目...
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技...
react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...