美文网首页前端
前端面试必问之Webpack

前端面试必问之Webpack

作者: 明明你也一样 | 来源:发表于2019-11-01 23:41 被阅读0次

概念

打包你的资源,webpack是把项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到你的项目的所有依赖文件,使用loaders处理它们,最后打包成一个或多个浏览器可识别的js文件

entry

entry: 用来指示webpack的入口文件,它将是整个依赖关系的根。webpack会从它开始帮你找到所有的依赖文件,并完成处理打包

var baseConfig = {
        entry: './src/index.js'
    }

当我们需要多个入口文件的时候,可以把entry写成一个对象

var baseConfig = {
        entry: {
            main: './src/index.js'
        }
    }

output

output: 属性告诉 webpack 在哪里输出它所创建(打包)的 bundles,以及如何命名这些文件。注意,即使入口文件有多个,但是只有一个输出配置。

var path = require('path')

var baseConfig = {
    entry: {
        main: './src/index.js'
    },
    output: {
        filename: 'main.js',
        path: path.resolve(__dirname, 'dist')
    }
}

module.exports = baseConfig

在上面的示例中,我们通过 output.filenameoutput.path 属性,来告诉 webpack bundle 的名称,以及我们想要 bundle 生成(emit)到哪里。可能你想要了解在代码最上面导入的 path 模块是什么,它是一个 Node.js 核心模块,用于操作文件路径。

如果你定义的入口文件有多个,那么我们需要使用占位符来确保输出文件的唯一性

output: {
        filename: '[name].js',
        path: __dirname + '/dist'
    }

如今这么少的配置,就能够让你运行一个服务器并在本地使用命令npm start或者npm run build来打包我们的代码进行发布

Loader

loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理。

var path = require('path')

var baseConfig = {
    entry: {
        main: './src/index.js'
    },
    output: {
        filename: 'main.js',
        path: path.resolve(__dirname, 'dist')
    },
    module: {
        rules: [
          { 
              test: /\.txt$/,
              use: 'raw-loader' 
          }
        ]
    }
}

module.exports = baseConfig

以上配置中,对一个单独的 module 对象定义了 rules 属性,里面包含两个必须属性:test 和 use。

  • test 属性,用于标识出应该被对应的 loader 进行转换的某种文件。
  • use 属性,表示进行转换时,应该使用哪个 loader。

还有 loader 的一些其他配置

    test: 匹配所处理文件的扩展名的正则表达式(必须)
    loader: loader的名称(必须)
    include/exclude: 手动添加处理的文件 / 屏蔽不需要处理的文件(可选)
    query: 为loaders提供额外的设置选项
    
        var baseConfig = {
            // ...
            module: {
                rules: [
                    {
                        test: /*匹配文件后缀名的正则*/,
                        use: [
                            loader: /*loader名字*/,
                            query: /*额外配置*/
                        ],
                        exclude: /node_modules/
                    }
                ]
            }
        }

列举一些常用的 loader

  • babel-loader:让下一代的js文件转换成现代浏览器能够支持的JS文件。
    注:babel有些复杂,所以大多数都会新建一个.babelrc进行配置
  • css-loader,style-loader:两个建议配合使用,用来解析css文件,能够解释@import,url(),如果需要解析less / sass就在后面加一个less-loader/sass-loader
  • file-loader:生成的文件名就是文件内容的MD5哈希值并会保留所引用资源的原始扩展名
  • url-loader: 功能类似 file-loader,但是文件大小低于指定的限制时,可以返回一个DataURL。事实上,在使用less,scss,stylus这些的时候,npm会提示你差什么插件,差什么,你就安装就行了

Plugin

loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量。

想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建它的一个实例。

const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通过 npm 安装
const webpack = require('webpack'); // 用于访问内置插件

const config = {
  module: {
    rules: [
      { test: /\.txt$/, use: 'raw-loader' }
    ]
  },
  plugins: [
    new HtmlWebpackPlugin({template: './src/index.html'})
    // 依据一个简单的index.html模版,生成一个自动引用你打包后的js文件的新index.html
  ]
};

module.exports = config;

参考

Webpack官方文档
前端面试之webpack篇

相关文章

  • 2020-01-19做些js的数组练习吧

    1.前端面试必问之数组去重 前端面试必问之数组去重 2.前端面试必问之深拷贝浅拷贝 3.

  • 前端面试必问之Webpack

    概念 打包你的资源,webpack是把项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到...

  • 前端面试必问之AJAX

    概述 AJAX全称是 Asynchronous JavaScript and XML,即异步JavaScript和...

  • 前端面试必问内容

    跨域如何实现 闭包 链式继承 http状态码 前端优化 对前端新技术的了解 react、vue、angular 前...

  • 前端面试必问的

    vue组件通讯的原则 1、父子通讯 props。2、子到父,用自定义事件。非父子组件,就用vuex,就行了

  • 前端面试必问总结

    前言 本文用于总结个人在工作期间总结的一些面试题 题目列表 js的函数声明 js的原型链 js的闭包 js的Pro...

  • 前端面试必问之数组去重

    基于数组API实现去重 创建一个空数组空间来比较循环数组中的每一项添加到空数组中,每次添加的时候验证一下,新数组中...

  • 面试必问之继承

    js继承常用的三种方法,记录一下,马上要面试了。 觉得有用可以帮我点个赞吗?谢谢了。

  • 面试必问之HashMap

    大家都知道,HashMap 的底层在 JDK 1.7 的时候为数组+链表,在JDK 1.8的时候为数组+链表+红黑...

  • 前端面试之webpack篇

    还是以前一样,有些概念面试可能会考,我都用*标记了出来,两句话就总结清楚其余的地方如果你想了解webpack,就仔...

网友评论

    本文标题:前端面试必问之Webpack

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