webpack是为现代js程序准备的静态模块打包工具

一:关于对webpack的理解

可以将其认为是一个电脑主板,由于使用js作为源码,因而其可以默认编译js代码(别种类型的文件可以依靠loaders或plugins),因为其底层由node提供支持,因而其支持编译common/esmodule的导入方式。而其被三大框架使用的原因是生态————提供了近乎所有文件的编译工具,这也使得webpack对整个前端工程的支持近乎全面。

二:安装

想要安装使用webpack,应首先确保安装node

截至当前,webpack更新到了5,笔者也使用的webpack5,node最低需12.x.x,可以命令行下使用node -v查看node版本

命令行下输入以下命令:

//全局安装
npm install webpack webpackcli -g //局部安装(推荐)
npm install webpack webpackcli -D
  • 问题1:推荐局部安装的原因

有时候可能项目的webpack版本不同,不同的webpack可能会存在不兼容

  • 问题2:为什么要安装webpackcli,

webpackcli并不是必需的,三大框架并没有安装webpackcli,安装webpackcli是由于当前命令行里需要webpackcli执行webpack内的命令且需要一些参数时,换句话说,此刻webpack需要webpackcli执行带参数的 命令,而webpackcli又依赖webpack(互相依存)

读者也可以指定webpack版本:

// 如:npm install webpack@3.6.0
npm install webpack@xxxxx

三:尝试写一个小demo

  • 如果全局安装了webpack:

    全局环境下,webpack命令可以在任一目录中使用

为演示webpack同时支持es6导入导出和common导入导出,以下两个非index.js文件使用两种方式

新建项目目录:

—mydemo

______src

——————__index.js

——————__common.js

——————__esmodule.js

——————index.html

//common.js
// node的导出流
const common_export = function(){
return '我是node的导出流'
}
module.exports = {
common_export
} //esmodule.js
// es6的导出流
export function es_export(){
return '我是esmodule的导出流'
} // index.js
import { es_export } from './esmodule'
const { common_export } = require('./common')
console.log(es_export(),common_export());

此时可以在mydemo目录命令行下输入webpack

即可生成一个dist目录,且内部生成一个main.js的文件,即如今项目结构显示如下:

—mydemo

______dist

——————__main.js

______src

——————__index.js

——————__common.js

——————__esmodule.js

——————index.html

假设读者有live-server这个插件且index.html中引入了./dist/main.js这个文件,在live on browers以后控制台会出现打印消息:

此时可以做个总结:

  1. webpack天然支持js的两种导入导出流
  2. 在输入webpack后会默认将当前目录下src目录中的index.js作为入口,且会默认在当前目录下生成dist目录并将打包后的js文件合并成./dist/main.js
  3. webpack天然支持生成静态文件,只需在index.html中引用打包后的main.js文件即可
  • 局部使用

    局部环境下,想要执行webpack命令,需要将webpack作为node中的一个包使用,此时,需要使用npm包管理器,换句话说,需要node支持

想要使用node环境,需要使用npm init命令生成package.json目录,这个目录记录当前npm的一些信息,可以在这里查看已安装的包目录

如果目录中有中文名,可以使用 npm init -y命令,这是由于node对中文的支持并不好

注:于全局目录此时保持一致

  1. 在新建目录下进行npm初始化

    npm init -y
  2. 下载webpack包

    npm install webpack -D

    -D是指开发时要用到的依赖,-S是生产环境也要用到的依赖

    如果此时package.json中显示有webpack包名,则说明局部安装成功

注意:此时此刻想要打包文件,不应使用webpack命令,因为一但使用webpack命令,则会使用全局的webpack进行打包————这与初衷不符

如何使用局部webpack命令打包项目?

  1. 可以使用.bin

使用.bin默认查找node-module下的webpack

.\node_modules\.bin\webpack

  1. 使用npx

使用npx将优先使用局部webpack,同方法1一样

npm webpack

  1. package.json的script字段中,使用命令(推荐使用)



    如果是这种方式,可以使用npm run build命令,此时将默认执行局部的webpack命令(本质上,所有局部查找的命令都是查找node-modules里的安装的包并且运行这个包)

下一记:webpack本身的配置以及其loader配置

最新文章

  1. JSP基础——属性保存范围和request对象
  2. Ideal-image-slider 幻灯片
  3. C# 设置开机自动启动(注册表方式)
  4. Oracle 10046 trace文件分析
  5. [Effective Java]第四章 类和接口
  6. 开源入侵检测系统OSSEC搭建之一:服务端安装
  7. 机器学习真的可以起作用吗?(2)(以二维PLA算法为例)
  8. Linux服务的管理
  9. Java ----------- SQL语句总结(更新中。。。。。。)
  10. BTE 增强
  11. viewpager+layout布局文件随数据多少创建滑动页面
  12. 利用火车头采集A67手机电影教程一
  13. jquery选择器筛选器
  14. Jmeter 问题集
  15. AngularJS中Directive指令系列 - bindToController属性的使用
  16. fork(2) - Linux man page
  17. DrawLayout使用侧滑抽屉
  18. 20155316 2016-2017-2 《Java程序设计》第1周学习总结
  19. 2018年计科五班秋季C语言基础课第1次作业
  20. QT5.3 杂记

热门文章

  1. Java 并发编程 生产者消费者模式
  2. 经典变长指令SIB
  3. OO 第三单元
  4. 周爱民带你深入剖析JavaScript核心原理
  5. Spring Boot 2.3 新特性优雅停机详解
  6. 树莓派WIFI
  7. 会议更流畅,表情更生动!视频生成编码 VS 国际最新 VVC 标准
  8. MVVM框架理解
  9. 女娲造人引发思考之Java设计模式:工厂模式
  10. k8s 使用nfs做provisioner