美文网首页我爱编程
webpack js压缩 css分离

webpack js压缩 css分离

作者: wdy934_ | 来源:发表于2018-04-10 23:24 被阅读0次

原本想按照网上的一些教程去做的, 但是, webpack4.0 去除掉了默认的js压缩插件, 或者说, 名字改掉了

我的优化方法如下(还可以再优化,后面再更新):

webpack4.0 以前的版本可以直接用: extract-text-webpack-plugin

webpack4.0之后的版本要加上: extract-text-webpack-plugin@next

extract-text-webpack-plugin :
某类型文件( 如: .less/.sass/.css)合并成一个文件 , 并从js分离

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
// const  webpackUglifyJsPlugin = require('uglify-js-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const extractLESS = new ExtractTextPlugin('stylesheets/[name]-two.css');
const extractCSS = new ExtractTextPlugin('stylesheets/[name]-one.css');
module.exports = {
    entry: [
        'babel-polyfill', path.resolve(__dirname, 'src/index.js')
    ],
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: 'bundle.js'
    },
    module: {
        rules: [
            {
                test: /\.(js|jsx)$/i,
                use: [
                    {
                        loader: 'babel-loader',
                        options: {
                            "presets": ["env", "react", "stage-2"]
                        }
                    }
                ],
                exclude: /node_modules/
            }, {
                test: /\.css$/i,
                use: extractCSS.extract({
                    fallback: 'style-loader',
                    use: ['css-loader']
                  })
            }, {
                test: /\.less$/i,
                use: extractLESS.extract({
                    fallback: 'style-loader',
                    use: ['css-loader', 'less-loader']
                  })
            }
        ]
    },
    resolve: {
        extensions: ['.js', '.jsx']
    },
    plugins: [
        new HtmlWebpackPlugin({title: 'manage', filename: "index.html", inject: 'body'}),
        new UglifyJsPlugin({
            parallel: 4,
            uglifyOptions: {
                output: {
                    comments: false,
                    beautify: false
                },
                compress: {},
                warnings: false
            },
            cache: true
        }),
        extractLESS,
        extractCSS
    ]
};

相关文章

  • webpack js压缩 css分离

    原本想按照网上的一些教程去做的, 但是, webpack4.0 去除掉了默认的js压缩插件, 或者说, 名字改掉了...

  • webpack 代码压缩

    js文件压缩 webpack 4 内置了uglifyjs-webpack-plugin,js默认是压缩过的 css...

  • webpack学习笔记(3)

    1、HTML、CSS和JS代码压缩 JS文件的压缩webpack4内置了uglifyjs-webpack-plug...

  • Web性能优化

    1、压缩及合并资源使用webpack或Parcel压缩图片、合并CSS和JS文件在线压缩图片网站:https://...

  • Node.js 在线便利贴

    技术栈 sass(css 预编译器) webpack(自动化构建工具,实现LESS,CSS,JS编译和压缩代码) ...

  • webpack压缩css和js

    压缩 CSS webpack5 貌似会内置 css 的压缩,webpack4 可以自己设置一个插件即可。 压缩 c...

  • webpack打包+热部署+maven打包

    webpack打包+热部署+mvn打包 webpack打包的作用:最后生成一个或者多个压缩后的js,css文件和一...

  • 优化资源

    文件最小化/文件压缩 js和css文件通过gulp,webpack等工具合并、压缩,减少用户流量,小图片可以在打包...

  • webpack 3.X学习之JS压缩与打包HTML文件

    js压缩 webpack自带一个插件uglifyjs-webpack-plugin来压缩js,所以不需要再次安装,...

  • 前端知识汇总(渲染篇)

    前端优化的手段 js css压缩合并 css在上,js在下(defer,async) 图片压缩、CSS-sprit...

网友评论

    本文标题:webpack js压缩 css分离

    本文链接:https://www.haomeiwen.com/subject/kduohftx.html