用webpack打包vue项目(单页面应用)的webpack.config设置详解

场景:
vue项目(单页面应用)已完成;
用webpack打包vue项目准备上线;

在项目根目录(手写)创建打包配置文件webpack.config.prod.js,框架及内容如下。

//引包:打包成页面用到的webpack+html
const webpack = require("webpack");
//htmlWebpackPlugin它的作用是根据chunk代码块生成文档
const htmlWebpackPlugin = require("html-webpack-plugin");
//引包:output需要用到字符串拼接
const path = require("path");
//引包:删除(旧的打包文件)dist目录
var cleanWebpackPlugin = require("clean-webpack-plugin");
//引包:抽离css的插件
const ExtractTextPlugin = require("extract-text-webpack-plugin")

module.exports = {
    entry:{ //(按实际写)这里放分解抽包后的入口文件-分解后的main.js
        // 在这里分了多少个口,main.js及其引包的js库与插件就会被分解抽包成多少个
        // 最后的 bundle:"./src/main.js"为拆解了各包后剩下的部分
        // 【格式】最终js文件名: ['vue包名1', "vue包名2"]
    },
    output:{  //(固定写法)为分解抽包的js文件指定路径
        path: path.resolve(__dirname, 'dist'),  //需拼接路径所以前面得引包path
        filename: 'js/[name].js'
    },
    module:{  //(按实际写)加载器:文件loader,处理不同的静态资源
        // 【格式】{ test:/\.后缀名$/,   use:['xx-loader'] },
        // 【格式】{ test:/\.(后缀|后缀)$/,   use:[ { loader:'xx-loader', opinions:{  }]  },
        // 【格式】{ test:/\.(后缀|后缀)$/,   use:插件.调用({ fallback:"xx-loader", use:[{ loader:'xx-loader', opinions:{  }}]  }),
    },
    resolve:{ //(固定写法)可以不加后缀, 直接使用 import xx from 'xx' 的语法
        extensions: ['.vue', '.js', '.css']
    },
    plugins:[ //(按实际写)生成html前,打包专用组件的各种优化操作,如删旧dist、压缩、抽出包等

        // (固定写法)删除旧的dist打包文件夹
        new CleanWebpackPlugin('dist'),
        //其实要删除文件的路径可以是多个,视具体情况而定

        //(固定写法) 配置html
        new htmlWebpackPlugin({
            template: './template.html',  //从这儿出发
            filename: 'index.html',    //导成这个
            minify:{    //(固定写法)html的压缩配置
                removeComments: true,//移除注释
                minifyJS: true,//压缩js
                minifyCSS: true,//压缩css
                collapseWhitespace: true,//去除空格
                // collapseWhitespace: true, //(段子黄未用)移除空白
                // removeAttributeQuotes: true  //(段子黄未用)移除属性中的双引号
            }
        }),

        new webpack.ProvidePlugin({//(固定写法)全局导入jquery,将jquery挂载到windows上
            // 用于有些库,比如jquery、bootstrap,打包不会出错,但是放在浏览器下就出问题,原因是bootstrap在初始化的时候要传入全局的jQuery变量,webpack中各模块都是独立的,jquery也是,jQuery无法赋值到window上,导致报错,这时候,这个插件就派上用场了,将jquery模块输出到全局的jQuery变量上。让bootstrap不再报错(没用bootstrap用了jQuery的话也要全局导入jQuery)
            $: "jquery",
            jQuery: "jquery"
        }),
        
        //(固定写法)设置当前环境为生产环境
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: '"production"'
            }
        }),

        //(固定写法)使用UglifyJs对js代码进行压缩
        new webpack.optimize.UglifyJsPlugin({
            compress: {
                warnings: false, //去掉警告
                drop_debugger: true, //去掉调试器和调试语句
                drop_console: true //去除console.log
            },
            comments: false //去掉版权信息等注释约1k,也可以保留
        }),

        //(按实际写)抽离第三方包,这里不要写bundle.js
        new webpack.optimize.CommonsChunkPlugin({
            //(按实际写)抽离的第三方包
            name: ["quanjiatong", "vue-lazyload", "v-distpicker", "vue-moment", "jquery", "axios"],
            // 对应 entry 中拆解打包后的js文件名,除了bundle以外按顺序倒着写
            // filename: "vendor.js" //这是干嘛的?乐东看到了请告诉我
            // (给 chunk 一个不同的名字)

            // (固定写法)(随着 entry chunk 越来越多,这个配置保证没其它的模块会打包进 vendor chunk)
            minChunks: Infinity,
        }),

         // (固定写法)通过插件抽离 css
        new ExtractTextPlugin("css/styles.css")
            //参数:传入路径,表示将抽离的css文件生成到哪个目录中
    ]
}

后续更新...
还缺少npm三个包的安装、.Babel文件es6转es5的配置、打包完成后的(字体图标等的)路径校准等.

  • package.json的scripts中增配置
    "build":"webpack --progress --config webpack.config.prod.js"

  • 打包命令行 npm run build

2018.3.26

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容

  • 喝酒 ------作者:萧莹 这天老公说道,明天是你的生日,要不让大哥一家来家里聚聚吧。 好吧,正好我也想喝酒了。...
    梁_木阅读 349评论 0 2
  • 晚上补看了向往的生活,印象深的其实还是他们吃饭时对于以前的追忆过往,对于这些我是百听不厌的。最开始接触这个节目,惊...
    默默喜欢你阅读 457评论 1 7