之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走:

在这里有:

  • 如何安装webpack
  • 如何使用webpack
  • 如何使用loader
  • 如何使用webpack的开发者服务器

一、安装webpack

你需要之前安装node.js

$ npm install webpack -g

安装成功后,便可以使用webpack命令行了。

ok,开始工作!

二、新建一个空目录,名字为myApp,文件如下

entry.js

document.write("It works.");

index.html文件

<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script type="text/javascript" src="bundle.js" charset="utf-8"></script>
</body>
</html>

此时并没有bunble.js文件,我们通过webpack命令来生成:

$ webpack ./entry.js bundle.js

这句命令会编译entry.js文件为新文件bunble.js。如果执行成功的话,会有如下结果:

Version: webpack 1.12.2
Time: 43ms
Asset Size Chunks Chunk Names
bundle.js 1.42 kB 0 [emitted] main
chunk {0} bundle.js (main) 28 bytes [rendered]
[0] ./tutorials/getting-started/setup-compilation/entry.js 28 bytes {0} [built]

然后,打开index.html,便会看出输出到屏幕上的It works.

三、使用模块的形式,进行简单的模块导出与加载

新建文件:content.js

module.exports = "It works from congtent.js";

然后,编辑entry.js文件:

var content = require("./content.js");
document.write(content);

然后,继续用webpack进行编译:

$ webpack ./entry.js bundle.js

此时浏览器变回输出It works from congtent.js

webpack会自己分析你的入口文件是否依赖其他文件,这些文件(或者模块)会引入到bundle.js中。webpack会给每个模块一个唯一的id,然后会在bundle.js中保存访问这些模块的id。刚开始的时候只有入口文件被执行,当碰到require的时候就会加载依赖。

四、使用第一个加载器

在目录中新建一个css文件,webpack自己只能处理js文件,需要css-loader来处理css文件,同时也需要style-loader去读取css文件中的样式。

安装这些加载器:

npm install css-loader style-loader

安装完成后,会在目录下多了一个node_modules文件夹,这些加载器就被下载到这里面。

新建style.css文件:

body {
background: yellow;
}

然后编辑入口文件:entry.js

require("!style!css!./style.css");
document.write(require("./content.js"));

此时,重新编译文件,刷新浏览器,会发现背景色变成黄色了。

$ webpack ./entry.js bundle.js

在引入css的时候,我们写了!style!css!,其实也可以不用写,可以将加载器绑定在webpack的命令中:

require("./style.css");
document.write(require("./content.js"));

然后,执行命令的时候把加载器一起输入:

webpack ./entry.js bundle.js --module-bind "css=style!css"

然后刷新浏览器,会发现结果是一样的。

五、利用配置文件

通过以上的方式,我们每次添加文件,都要写一个规则,然后在编译执行,确实很麻烦,webpack可以通过配置文件来简化这些事情:

新建webpack.config.js文件,并利用如下规则

module.exports = {
entry: "./entry.js",
output: {
path: __dirname,
filename: "bundle.js"
},
module: {
loaders: [
{ test: /\.css$/, loader: "style!css" }
]
}
};

然后执行命令的时候只需要一个webpack即可:

$ webpack

执行webpack后,会搜索当前目录下的webpack.config.js文件,并加载。

以上的配置文件和之前的代码执行的效果相同,只不过是将规则写入到了一个配置中,可以更方便灵活的进行配置。其实配置也很明朗:入口文件、出口文件、加载器。

六、更漂亮的输出结果

之前有输出结果,不够直观,webpack可以通过几个配置项来美化输出结果:

  • 进度条:progress

如果文件很多,我们需要知道当前正在编译哪个文件,还有颜色

webpack --progress --colors
  • 观察模式:watch

所谓观察模式,即监听模式,如果有文件改变,则自动编译:

webpack --progress --colors --watch

七、开发者服务器

所谓开发者服务是启动webpack提供的服务器,所有的测试在该服务器下进行。需要安装webpack-dev-server

npm install webpack-dev-server -g

然后,启动该服务器即可:

webpack-dev-server --progress --colors

此时,会自动启动一个端口为8080的服务器,在浏览器中访问:http://localhost:8080就可以访问了。

如果文件有该改变,代码会自动编译并且自动刷新浏览器。相当于绑定了watch模式。

需要注意的是,访问http://localhost:8080是无法自动刷新的,需要访问http://localhost:8080/webpack-dev-server/bundle,你修改文件,该页面会自动刷新。

原文地址:js学习笔记:webpack基础入门(一)

js学习笔记:webpack基础入门(一)的更多相关文章

  1. Vue学习笔记-Vue基础入门

    此篇文章是本人在学习Vue是做的部分笔记的一个整理,内容不是很全面,希望能对阅读文章的同学有点帮助. 什么是Vue? Vue.js (读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式 ...

  2. 《马哥出品高薪linux运维教程》wingkeung学习笔记-linux基础入门课程

    计算机原理概念: 1.CPU和内存中的存储单元通信线路称为总线(BUS),总线是被指令和数据复用的,所以也称为前端总线. 2.计算机中计算频率的时间标准即晶体振荡器原理,精确计算时间长度,根据相同的时 ...

  3. JS学习笔记1_基础与常识

    1.六种数据类型 5种基础的:Undefined,Null,Boolean,Number,String(其中Undefined派生自Null) 1种复杂的:Object(本质是一组无序键值对) 2.字 ...

  4. Vue.js学习笔记--1.基础HTML和JS属性的使用

    整理自官网教程 -- https://cn.vuejs.org/ 1. 在HTML文件底部引入Vue <script src="https://cdn.jsdelivr.net/npm ...

  5. 006 SpringCloud 学习笔记2-----SpringCloud基础入门

    1.SpringCloud概述 微服务是一种架构方式,最终肯定需要技术架构去实施. 微服务的实现方式很多,但是最火的莫过于Spring Cloud了.SpringCloud优点: - 后台硬:作为Sp ...

  6. Vue.js学习笔记--2.基础v-指令

    整理自官网教程 -- https://cn.vuejs.org/ 1. v-bind绑定Class与Style a. 绑定Class 语法:v-bind:class="{classname: ...

  7. java 从零开始,学习笔记之基础入门<Oracle_基础>(三十三)

    Oracle 数据库基本知识   [训练1] 显示DEPT表的指定字段的查询.               输入并执行查询:               SELECTdeptno,dname FROM ...

  8. java 从零开始,学习笔记之基础入门<集合>(十六)

    集合 集合:将多个元素放入到一个集合对象中去,对应的集合对象就可以用来存储多元素. Collection接口的子接口:Set接口和List接口. Map不是Collection接口的子接口. Coll ...

  9. 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案

    初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...

随机推荐

  1. jQuery.Ajax IE8 无效(CORS)

    今天在开发的时候,遇到一个问题,$.get()在 IE8 浏览器不起作用,但 Chrome,Firefox 却是可以的,网上资料很多,最后发现是 IE8 默认不支持 CORS 请求,需要手动开启下: ...

  2. 在Windows上编译和调试CoreCLR

    生成CoreCLR - Windows篇 本文的唯一目的就是让你运行Hello World 运行环境 Window 7+ Visual studio 2015 确保C++ 工具已经被安装,默认是不安装 ...

  3. bzoj4724--数论

    题目大意: B进制数,每个数字i(i=0,1,...,B-1)有a[i]个.你要用这些数字组成一个最大的B进制数X(不能有前导零,不需要 用完所有数字),使得X是B-1的倍数.q次询问,每次询问X在B ...

  4. SharePoint 2013管理中心里【管理服务器上的服务】不见了

    打开管理中心,准备配置Managed Metadata Service,发现"管理服务器上的服务"不见了 那我自己拼url直接访问:http://xxxx/_admin/Serve ...

  5. Linux网络属性配置

    目录 IP地址分类 如何将Linux主机接入到网络中 网络接口的命名方式 ifcfg系列命令 如何配置主机名 如何配置DNS服务器指向 iproute2系列命令 Linux管理网络服务 永久生效配置路 ...

  6. Linux C语言解析并显示.bmp格式图片

    /************************* *bmp.h文件 *************************/ #ifndef __BMP_H__ #define __BMP_H__ # ...

  7. 将css和js缓存到localStorage缓存,提高网页响应速度

    适用于小站点,这很极致,很快速~~ /** * Created by SevenNight on 2016/9/21 0021. * 插件功能:使用localStorage缓存js和css文件,减少h ...

  8. 一键部署mono 免费空间支持ASP.NET MVC 再也不担心伙食费换空间了

    一直以来 部署mono 都是很头疼的事情 因为是我在是不熟悉非win环境,今天偶然发现这个项目,挺好的,分享下 https://github.com/wshearn/openshift-communi ...

  9. 在 Ubuntu 14.10 中借用 Windows 的字体

    在前一篇随笔中,我详细讨论了字体的分类及用途,也以 Fedora 20 为例,展示了字体配置的思路和方法.我在配置 Fedora 20 系统字体的时候,采用的是一种釜底抽薪的方法,完全抛开了系统原有的 ...

  10. 探索 Linux 系统的启动过程

    引言 之所以想到写这些东西,那是因为我确实想让大家也和我一样,把 Linux 桌面系统打造成真真正正日常使用的工具,而不是安装之后试用几把再删掉.我是真的在日常生活和工作中都使用 Linux,比如在 ...