02. 开始使用webpack

1.1、安装

Webpack可以使用npm安装,新建一个空的练习文件夹(此处命名为webpack sample project),在终端中转到该文件夹后执行下述指令就可以完成安装。

//全局安装
npm install -g webpack
//安装到你的项目目录
npm install --save-dev webpack

1.2、正式使用Webpack前的准备

1.在终端中使用npm init命令可以自动创建这个package.json文件

npm init

2.package.json文件已经就绪,我们在本项目中安装Webpack作为依赖包

// 安装Webpack
npm install --save-dev webpack

3.回到之前的空文件夹,并在里面创建两个文件夹,app文件夹和public文件夹,app文件夹用来存放原始数据和我们将写的JavaScript模块,public文件夹用来存放之后供浏览器读取的文件(包括使用webpack打包生成的js文件以及一个index.html文件)。接下来我们再创建三个文件:

* index.html --放在public文件夹中;
* Greeter.js-- 放在app文件夹中;
* main.js-- 放在app文件夹中;

在index.html文件中写入最基础的html代码,它在这里目的在于引入打包后的js文件(这里我们先把之后打包后的js文件命名为bundle.js,之后我们还会详细讲述)。

<!-- index.html -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Webpack Sample Project</title>
</head>
<body>
<div id='root'>
</div>
<script src="bundle.js"></script>
</body>
</html>

我们在Greeter.js中定义一个返回包含问候信息的html元素的函数,并依据CommonJS规范导出这个函数为一个模块:

// Greeter.js
module.exports = function() {
var greet = document.createElement('div');
greet.textContent = "Hi there and greetings!";
return greet;
};

main.js文件中我们写入下述代码,用以把Greeter模块返回的节点插入页面。

//main.js
const greeter = require('./Greeter.js');
document.querySelector("#root").appendChild(greeter());

1.3 正式使用Webpack

webpack可以在终端中使用,在基本的使用方法如下:

# {extry file}出填写入口文件的路径,本文中就是上述main.js的路径,
# {destination for bundled file}处填写打包文件的存放路径
# 填写路径的时候不用添加{}
webpack {entry file} {destination for bundled file}

指定入口文件后,webpack将自动识别项目所依赖的其它文件,不过需要注意的是如果你的webpack不是全局安装的,那么当你在终端中使用此命令时,需要额外指定其在node_modules中的地址,继续上面的例子,在终端中输入如下命令

# webpack非全局安装的情况
node_modules/.bin/webpack app/main.js public/bundle.js

运行结果

运行结果

1.4 通过配置文件来使用Webpack

在当前练习文件夹的根目录下新建一个名为webpack.config.js的文件,我们在其中写入如下所示的简单配置代码,目前的配置主要涉及到的内容是入口文件路径和打包后文件的存放路径。

module.exports = {
entry: __dirname + "/app/main.js",//已多次提及的唯一入口文件
output: {
path: __dirname + "/public",//打包后的文件存放的地方
filename: "bundle.js"//打包后输出文件的文件名
}
}

注:“__dirname”是node.js中的一个全局变量,它指向当前执行脚本所在的目录。

有了这个配置之后,再打包文件,只需在终端里运行webpack(非全局安装需使用node_modules/.bin/webpack)命令就可以了,这条命令会自动引用webpack.config.js文件中的配置选项,示例如下:

1.5 更快捷的执行打包任务

过值得庆幸的是npm可以引导任务执行,对npm进行配置后可以在命令行中使用简单的npm start命令来替代上面略微繁琐的命令。在package.json中对scripts对象进行相关设置即可,设置方法如下。

{
"name": "webpack-sample-project",
"version": "1.0.0",
"description": "Sample webpack project",
"scripts": {
"start": "webpack" // 修改的是这里,JSON文件不支持注释,引用时请清除
},
"author": "zhang",
"license": "ISC",
"devDependencies": {
"webpack": "3.10.0"
}
}

注:package.json中的script会安装一定顺序寻找命令对应位置,本地的node_modules/.bin路径就在这个寻找清单中,所以无论是全局还是局部安装的Webpack,你都不需要写前面那指明详细的路径了。

npm的start命令是一个特殊的脚本名称,其特殊性表现在,在命令行中使用npm start就可以执行其对于的命令,如果对应的此脚本名称不是start,想要在命令行中运行时,需要这样用npm run {script name}如npm run build,我们在命令行中输入npm start试试,输出结果如下:

最新文章

  1. SQL之收集SQL Server线程等待信息
  2. MEF 根据配置注入Service
  3. [Android] 修改ImageView的图片颜色
  4. SQL Server 数据类型
  5. c++垃圾回收代码练习 引用计数
  6. 分布式发布订阅消息系统 Kafka 架构设计
  7. 解决statusStrip控件上的项目不能靠右对齐的问题
  8. md5可能会被破解咋办?
  9. gerrit git使用
  10. Python开发 文件操作
  11. netcore项目在Centos部署:nohup和supervisor方式
  12. [Swift]LeetCode790. 多米诺和托米诺平铺 | Domino and Tromino Tiling
  13. python 格式话-占位符
  14. sersync 开机自启 (仅供自己参考)
  15. Java语法基础学习DayFifteen(IO续)
  16. Java备份文件
  17. C# Post HTTP Request
  18. Redux-example
  19. [Android] 压缩图片并保存
  20. aiohttp基本及进阶使用

热门文章

  1. 这一次,彻底理解Promise源码思想
  2. ThinkCMF X1.6.0-X2.2.3框架任意内容包含漏洞分析复现
  3. Nexus 上传项目到私服
  4. Fine-Grained(细粒度) Image – Papers, Codes and Datasets
  5. 就因为加了Lombok的@Accessors(chain = true),bean拷贝工具类不干活了
  6. 第四十章 POSIX条件变量
  7. oracle数据库锁表,什么SQL引起了锁表?ORACLE解锁的方法
  8. 为什么磁盘慢会导致Linux负载飙升?
  9. C++学习笔记4_new和delete
  10. 05 MySQL之查询、插入、更新与删除