## 本地化安装webpack ##

1. npm init //npm初始化生成package.json文件
2. npm install --save-dev webpack //安装webpack,dev表示安装到开发环境,save表示本地安装
3. 如果是老项目,有package.json文件,直接运行npm i 安装对应的依赖包

## webpack快速打包 ##

webpack src/entery.js dist/bundle.js 
//将entery.js打包到bundle.js
如果有配置文件,直接运行webpack即可

## package.json ##

{
        "name":"webpacktest",
        "version":"1.0.0",
        "description":"test webpack",
        "main":"index.js",
        "scripts":{ //本地npm启动命令:npm run xxxx
            "server":"webpack-dev-server --open",
            //open表示自动打开
            "build":"set type=build&webpack", //node语法,传递参数
            "dev":"set type=dev&webpack" //mac或linux:export type=dev&&webpack
        },
        "author":"tabb",
        "license":"ISC",
        "devDependencies":{  //开发依赖 --save-dev
            "webpack":"^3.6.0",
            "webpack-dev-server":"^2.8.2"
        },
        "dependencies":{  //生产依赖 --save 'npm install --production'(项目上线只安装生成包)
            
        }
    }

## webpack config ##

配置文件webpack.config.js
    const glob=require("glob");  //引入全局控制插件
    const path=require('path'); //引入路径模块
    const uglify=require('uglify-webpack-plugin'); //引入js代码自动压缩模块
    const htmlPlugin=require('html-webpack-plugin'); //引入html打包插件
    const extractTextPlugin=require('extract-text-webpack-plugin'); //引入文件分离插件
    const purifyCSSPlugin=require("purfiycss-webpack"); //引入css冗余删除插件
    const copyWebpackPlugin=require("copy-webpack-plugin"); //引入静态资源处理
    //根据配置传值,打包出不同的根目录,区分生产环境和开发环境
    if(process.env.type="build"){ //node语法
        var website={
            publicPath:"http://tabb.com/"    //设置根路径
        }        
    }else{
        var website={
            publicPath:"http://192.168.0.104/"    //设置根路径
        }    
    }
    var website={
        publicPath:"http://192.168.0.104/"    //设置根路径
    }
    module.exports={
        entry:{ //入口文件路径
            entry1:'./src/entry1.js',
            entry2:'./src/entry2.js',
            jquery:'jquery',
            vue:'vue'
        },
        output:{ //出口文件
            path:path.resolve(__dirname,'dist'),
            filename:'bundle.js' //可写[name],js保持与入口文件名一致
            publicPath:website.publicPath //设置项目引用的公共路径
        },
        module:{
            rules:[ //css打包
                {
                    test:/\.css$/,  //正则匹配对应需要处理的文件
                    use:['style-loader','css-loader']  //添加打包需要使用的功能模块
                    //也可以写成如下形式
                    use:[{
                        loader:'style-loader'
                    },{
                        loader:'css-loader'
                    },
                    "postcss-loader" //css3自动加前缀
                    ],
                    //extract抽离处理
                    use:extractTextPlugin.extract({
                        fallback:"style-loader",
                        use:"css-loader"
                    })                
                },
                {
                    test:/\.(png|jpg|gif)/, //处理图片
                    use:[
                        {
                            loader:'url-loader',
                            boptions:{
                                limit:5000  //设置图片小于多大显示为base64编码
                                outputPath:"images/" //配置图片生成路径
                            }
                        }
                    ]
                },
                { //处理html中image标签引用图片
                    test:/\.(htm|html)$/i,
                    use:['html-withimg-loader']
                },
                { //处理less文件
                    test:/\.(htm|html)$/i,
                    use:[
                        {
                            loader:"style-loader"
                        },{
                            loader:"css-loader"
                        },{
                            loader:"less-loader"
                        }
                    ]                
                },
                { //babel配置
                    test:/\.(jsx|js)$/,
                    use:{
                        loader:"babel-loader",
                        options:{
                            presets:["es2015","react"]
                        }
                    },
                    exclude:/node_modules/                    
                }
            ]
        },
        plugins:[
            new copyWebpackPlugin({ //处理静态资源
                from:__dirname + "/src/public", //静态资源来源
                to:"./public" //默认到dist目录下
            }), 
            new webpack.optimize.CommonsChunkPlugin({ //配置第三方插件抽离打包
                name:['jquery','vue'], //对应入口配置entry中的key
                filename:"assets/js/[name].[ext]", //配置输出路径,可将[ext]改为js,[name]自动匹配配置的名称
                minChunks:2 
            })
            new webpack.ProvidePlugin({
                $:"jquery"
            }),
            new uglify(), //开发环境会报错,因为开发环境代码100%不压缩
            new htmlPlugin({
                minify:{ //配置压缩条件
                    removeAttributeQuotes:true //去除标签中的引号
                },
                hash:true, //给引入的js添加hash,保证加载新文件,防止缓存
                template:'./src/index.html'
            }),
            new extractTextPlugin("/css/index.css"), //指定css分离打包路径
            new purifyCSSPlugin({
                paths:glob.sync(path.join(__dirname,'src/*.html'))  //全局搜索html文件中的dom,找到有效的css
            }),
            new webpack.BannerPlugin("tabb版权所有") //设置打包文件的title注释
        ],
        devServer:{ //开发服务配置,需要安装webpack-dev-server 
            contentBase:path.resolve(__dirname,'dist'), //基本目录结构
            host:'192.168.0.104', //服务器host
            compress:true, //服务器是否启用压缩
            port:1717  //端口
        },
        watchOptions:{  //自动监测watch打包配置
            poll:1000, //监测修改的时间
            aggregeateTimeout:500, //表示500ms内重复按键ctrl+s不进行打包
            ignored:/node_modules/,  //忽略监视项
        }
    }

## babel配置文件,babelrc ##

{
        presets:["env","react"] //env转换es6,es7等
    }

## webpack中的工具安装 ##

1. webpack-dev-server //热更新工具
2. style-loader   //样式处理
3. css-loader   //css文件处理
4. uglify-webpack-plugin  //js自动压缩插件
5. html-webpack-plugin  //html打包插件
6. url-loader  //处理路径
7. file-loader //处理加载文件
8. extract-text-webpack-plugin  //抽离css等文件打包
9. html-withimg-loader  //处理html中使用img标签引用图片
10. less less-loader //less编译
11. sass sass-loader  //sass编译
12. postcss-loader autoprefixer //css3自动添加前缀依赖
13. purify-css purify-webpack  //自动删除css冗余
14. babel-core babel-loader babel-preset-es2015 babel-preset-react babel-preset-env //babel用于编译es6等语法,以及react中的jsx
15. webpack.ProvidePlugin  //统一配置引入插件
16. webpack.optimize.CommonsChunkPlugin //配置第三方插件抽离打包
17. copy-webpack-plugin //静态资源打包

webpack3基础知识的更多相关文章

  1. .NET面试题系列[1] - .NET框架基础知识(1)

    很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...

  2. RabbitMQ基础知识

    RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...

  3. Java基础知识(壹)

    写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...

  4. selenium自动化基础知识

    什么是自动化测试? 自动化测试分为:功能自动化和性能自动化 功能自动化即使用计算机通过编码的方式来替代手工测试,完成一些重复性比较高的测试,解放测试人员的测试压力.同时,如果系统有不份模块更改后,只要 ...

  5. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  6. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  7. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  8. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  9. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

随机推荐

  1. python2.7练习小例子(五)

        5):题目:输入三个整数x,y,z,请把这三个数由小到大输出.     程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比 ...

  2. Django信号的使用

    https://www.cnblogs.com/renpingsheng/p/7566647.html

  3. Linux 下 PHP 扩展Soap 编译安装

    1.进入 PHP 的软件包 pdo 扩展目录中(注:不是 PHP 安装目录) [root@tester /]# /home/tdweb/php-5.4.34/ext/soap 执行 phpize 命令 ...

  4. [网站公告]18:07-18:20阿里云SLB故障造成网站不能正常访问

    (注:由于阿里云SLB管理控制台监控数据不准,实际故障时间是18:07-18:20.) 17:55-18:2018:07-18:20,我们使用的阿里云SLB(负载均衡)中有3台出现突发故障,造成全站无 ...

  5. python 基础篇 11 函数进阶----装饰器

    11. 前⽅⾼能-装饰器初识本节主要内容:1. 函数名的运⽤, 第⼀类对象2. 闭包3. 装饰器初识 一:函数名的运用: 函数名是一个变量,但他是一个特殊变量,加上括号可以执行函数. ⼆. 闭包什么是 ...

  6. 望岳物业App开发过程记录

    望岳物业APP开发过程记录 ——杜冰青 1.小组讨论,决定模块功能. 2.开始做“社区活动”界面,完成主页面.分享界面.内容界面,但是分享功能暂时没有完成. 3.接着做“一键开门”界面,因为硬件设施跟 ...

  7. Daily Scrum02 12.03

    Daily Scrum03 12.03 一天过去了,新的一天即将到来,我们组仍旧干劲十足呢~ Member Today's Task Tomorrow's Task 李孟 孟神有点累了呢 task85 ...

  8. BST插入与查找

    B树: 二叉查找树,所有左节点都比父节点要小,所有右节点都比父节点要大.查找,插入的时间复杂度为O(logn) public class BTreeTest { public static int[] ...

  9. JavaWeb 基于Session的用户登陆注销实现

    通过Session来存储用户的部分登陆信息来验证用户是否在线,这应该时最容易实现的一种Web端方案,本文以SSM(Spring.SpringMVC.myBatis)框架为载体,来具体实现这套登陆系统. ...

  10. 写一篇Hook Driver.

    关于Hook,有一本书讲的比较清楚,最近刚刚看完,<Rootkits: Subverting the Windows Kernel> http://www.amazon.com/Rootk ...