webpack
简介
Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。在前端工程化中特别常用。
初始化项目
1、创建文件夹testProject,使用vscode打开该文件夹,打开终端,执行命令
npm init   //得到package.json的一个文件
 
2.安装webpack
npm install  webpack webpack-cli
 
3.构建测试项目代码
 创建src文件夹,存放需要合并的js文件
 util.js文件
exports.add = function (a, b) {
    return a + b;
}
 
common.js文件
exports.info = function (str) {
   //往浏览器输出
   document.write(str);
}
 
src下创建main.js的入口文件
//将所有的js文件进行引入到一个文件中
const common = require('./common');
const utils = require('./utils');
common.info('Hello world!' + utils.add(100, 200));
 
4、在根目录下定义webpack.config.js文件配置打包的规则
const path = require("path"); //Node.js内置模块
module.exports = {
    entry: './src/main.js', //配置入口文件
    output: {
        path: path.resolve(__dirname, './dist'), //输出路径,__dirname:当前文件所在路径
        filename: 'bundle.js' //输出文件
    }
}
//执行webpack时会找到这个文件,然后根据entry找到main.js从而将需要的文件进行打包
//合并完成后,写入到dist目录下的bundle.js文件
 
5.创建测试的test.html引用生成的bundle.js
<!DOCTYPE html>
<html lang='en'>
<head>
    <meta charset='UTF-8'>
    <title></title>
    <style>
         *{
            margin:0;
            padding:0;
            box-sizing:border-box;
            -webkit-tap-highlight-color:transparent;
        }
    </style>
</head>
<body>
    <script src="../dist/bundle.js"></script>
    <script>
    </script>
</body>
</html>
 
6.配置package.json,加入命令
"scripts": {   
        //...,    
        "dev": "webpack -w --mode=development" 
        }
 
7.运行命令,进行打包
  npm run dev
 
8.打开test.html查看效果
补充
Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换。
Loader 可以理解为是模块和资源的转换器。
 1、安装style-loader和 css-loader
//css-loader 是将 css 装载到 javascript
//style-loader 是让 javascript 认识css
//安装完后,就会在package.json中产生依赖
npm install --save-dev style-loader css-loader
 
2、修改webpack.config.js,配置CSS打包的规则
const path = require("path"); //Node.js内置模块
module.exports = {
    //...,
    output:{
        //其他配置
    },
    module: {
        rules: [  
            {  
                test: /\.css$/,    //打包规则应用到以css结尾的文件上
                use: ['style-loader', 'css-loader']
            }  
        ]  
    }
}
 
这时候就可以把css也进行打包啦










