美文网首页
1.webpack初识webpack

1.webpack初识webpack

作者: 小棋子js | 来源:发表于2019-12-23 14:53 被阅读0次

1. 什么是webpack

先来看看官网对webpack的介绍 :

本质上,webpack是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个bundle

简单来说webpack就是一个JavaScript的打包器,将各种模块(module)打包成资源文件;还可以通过 Code Spliting 来把代码分离到不同的 bundle 中,然后可以按需加载或并行加载这些文件;webpack 可以使用 loader 来预处理文件,这允许你打包除了JavaScript 之外的任何静态资源。

官网首页很清晰的展示了webpack的主要功能:

image

我们可以看到,一堆 modules 经过 webpack 打包处理成了各种静态资源。这就是 webpack

2. webpack核心概念

在开始学习 webpack 之前,你需要了解 webpack 的四个核心概念:

  • 入口(entry)
  • 出口(output)
  • loader
  • 插件(plugins)

2.1 入口(entry)

入口指示 webpack 应该使用哪个模块,来开始构建其内部依赖。进入入口后,webpack 会找出有哪些模块和库是与入口相依赖的。

我们可以在webpack配置中配置entry属性,来设置一个或多个入口起点。以下是一个简单的entry配置:

const config = {
  entry: {
    main: 'path/to/your/entry/index.js'
  }
}
module.exports = config

2.2 出口(output)

设置output是为了告诉webpack要在哪里输出其创建的bundle,并且可以对bundle命名。示例:

const path = require('path')
const config = {
  entry: {
    main: 'path/to/your/entry/index.js'
  },  
  output: {
    filename:'[name].bundle.js',
    path: path.join(__dirname,'./dist')  
  }
}
module.exports = config

我们通过 output.filename 来设置输出bundle的文件名, output.path 来设置 bundle 的输出路径

path 是 nodeJs 中的核心模块,用来处理项目中的路径。

2.3 loader

由于 webpack 只认识 JavaScript 代码,因此就需要借助其他方法来处理那些非 JavaScript 文件,如 css、image、font等。而 loader 可以将所有类型的文件处理成 webpack 能够识别的有效模块,然后再对其进行处理。

loader 中有两个重要属性:
  1. test属性,用于标识出应该被对应的 loader 进行转换的某个或某些文件,通常是一个正则表达式;
  2. use属性,表示进行转换时,应该使用哪个 loader;
const path = require('path')

const config = {
  entry: {
    main: 'path/to/your/entry/index.js'
  },
  output: {
    filename: '[name].bundle.js',
    path: path.join(__dirname, './dist')
  },
  module: {
    loaders: [
      {
        test: /\.ejs$/,
        use: ['ejs-loader']
      }
    ]
  }
}

module.exports = config

以上示例中loader的配置相当于告诉webpack在遇到 .ejs 的文件时,在打包之前先用 ejs-loader 装换一下。

2.4 插件(plugins)

loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。想要使用一个插件,你只需要require()它,然后把它添加到plugins数组中。多数插件可以通过选项(option)自定义。

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin') // 通过 npm 安装

const config = {
  entry: {
    main: 'path/to/your/entry/index.js'
  },
  output: {
    filename: '[name].bundle.js',
    path: path.join(__dirname, './dist')
  },
  module: {
    loaders: [
      {
        test: /\.ejs$/,
        use: ['ejs-loader']
      }
    ]
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: 'webpack demo',
      template: path.join(__dirname, './index.html')
    })
  ]
}

module.exports = config

HtmlWebpackPlugin 将为你生成一个 HTML5 文件, 其中包括使用script标签的 body 中的所有 webpack 包,webpack 提供提供了许多功能强大的插件,查阅插件列表获取更多插件的使用方法。

相关文章

  • 1.webpack初识webpack

    1. 什么是webpack 先来看看官网对webpack的介绍 : 本质上,webpack是一个现代 JavaSc...

  • webpack

    1.webpack的全局安装 $ npm install webpack -g 2.webpack的使用 eg.编...

  • 学习webpack看过的文章

    1.Webpack入门,介绍比较全面 入门Webpack,看这篇就够了 2.webpack-dev-server相...

  • 2019-06-18

    一、webpack安装方式 1.webpack全局安装 npm install webpack@版本号(可用npm...

  • webpack简单使用

    一、webpack简介 1.webpack是什么 webpack项目打包工具,项目构建工具 2.webpack有什...

  • webpack

    1.webpack简介 1.1 webpack是什么? CommonJS和AMD是用于JavaScript模块管理...

  • webpack的练习心得

    1.webpack单文件打包webpack src/entry.js dist/bundle.js (webpac...

  • 2019-12-20

    1.webpack应用实例 #1.1.快速上手 初始化项目 安装webpack 零配置使用webpack,webp...

  • webpack 基础一 1002

    webpack 基础一 1.webpack开篇 2.webpack配置文件 2.1 js代码如下 2.2 配置文件...

  • 前端知识体系4.前端工程化1.Webpack专题

    本文目录: 1.webpack的定义及基础核心概念 2.webpack构建原理 3.webpack运行的基本流程 ...

网友评论

      本文标题:1.webpack初识webpack

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