[关闭]
@brizer 2016-02-02T21:00:48.000000Z 字数 2698 阅读 1832

Webpack之入门教程二号


前言

前面我们学习了WebPack的安装和入门教程,了解了基本的编译流程和webpack.config.js配置文件的运用。接下来我们继续WebPack的使用。


引用

首先新建一个空文件夹,格式如下:

/app
--main.js
--component.js
/build
--bundle.js (自动创建)
--index.html
package.json
webpack.config.js

在该目录运行npm init,完成基本配置项:

然后我们配置webpack.config.js文件如下:

  1. var path=require("path");
  2. module.exports = {
  3. entry:path.resolve(__dirname,"app/main.js"),
  4. output:{
  5. path:path.resolve(__dirname,"build"),
  6. filename:"bundle.js",
  7. },
  8. };

将入口和输出指定好。

接下来我们编写app/component.js文件:

  1. 'use strict';
  2. module.exports = function(){
  3. var element = document.createElement("h1");
  4. element.innerHTML = "Hello world";
  5. return element;
  6. };

还有app/main.js:

  1. 'use strict'
  2. var component = require("./component.js");
  3. document.body.appendChild(component());

接下来运行webpack命令:

会发现bundle.js文件已经自动生成了。其作用就是绑定和对应webpack.config.js中的入口和输出,这一点我们在前面的文章中也说过。

最后是index.html:

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Document</title>
  6. </head>
  7. <body>
  8. <script src="bundle.js"></script>
  9. </body>
  10. </html>

在浏览器中访问index.html就可以得到hello world了。


自定义命令

之前我们是通过webpack命令来进行编译,接下来我们通过在package.json中自定义命令build来执行webpack:

  1. {
  2. "name": "webpacktest",
  3. "version": "1.0.0",
  4. "description": "webpack",
  5. "main": "index.js",
  6. "scripts": {
  7. "test": "echo \"Error: no test specified\" && exit 1",
  8. "build":"webpack"
  9. },
  10. "author": "",
  11. "license": "ISC"
  12. }

然后我们就可以执行npm run build 来进行编译了:

当我们的项目非常复杂时,可以通过这种自定义scripts的方式来保存界面的简洁。


配置服务器

我们每次都通过npm run build 然后刷新有点不太方便。我们可以通过设置webpack-dev-server来完成自动刷新。

首先输入 npm i webpack-dev-server --save,此外,我们需要去调整 package.json scripts 部分去包含这个指令:

  1. "scripts": {
  2. "test": "echo \"Error: no test specified\" && exit 1",
  3. "build": "webpack",
  4. "dev": "webpack-dev-server --devtool eval --progress --colors --hot --content-base build"
  5. },

这样我们就可以通过命名 npm run dev 来执行以下命令:

webpack-dev-server - 在 localhost:8080 建立一个 Web 服务器
--devtool eval - 为你的代码创建源地址。当有任何报错的时候可以让你更加精确地定位到文件和行号
--progress - 显示合并代码进度
--colors - Yay,命令行中显示颜色!
--content-base build - 指向设置的输出目录

我们就可以通过访问http://localhost:8080/来查看效果了,web服务器会监听文件修改,并重新合并我们的代码,非常方便。

这次我们将content.js修改如下:

  1. 'use strict';
  2. module.exports = function(){
  3. var element = document.createElement("h1");
  4. element.innerHTML = "Hello world!!";
  5. return element;
  6. };

刷新index.html没有反应,刷新localhost:8080则有反应,这就说明webpack-server-dev起作用了。


自动刷新

前面说到,我们需要刷新localhost:8080才会有反应,如果我们需要文件改变后应用自动刷新呢?

我们需要设置webpack.config.js:

  1. var path=require("path");
  2. module.exports = {
  3. entry:[
  4. "webpack/hot/dev-server",
  5. "webpack-dev-server/client?http://localhost:8080",
  6. path.resolve(__dirname,"app/main.js"),
  7. ],
  8. output:{
  9. path:path.resolve(__dirname,"build"),
  10. filename:"bundle.js",
  11. },
  12. };

然后重新运行npm run dev,再修改文件后,localhost:8080中的内容就会自动更新了。


模块

之前一直没有提到的,就是WebPack运行我们使用不同的模块定义方式:
ES6 模块

import MyModule from './MyModule.js';

CommonJS

var MyModule = require('./MyModule.js');

AMD

define(['./MyModule.js'], function (MyModule) {

});

相对路径和绝对路径:

  1. // ES6 相对路径
  2. import utils from './../utils.js';
  3. // ES6 绝对路径
  4. import utils from '/utils.js';

相对路径是相对当前目录,绝对路径是相对入口文件。


参考

第一步
开始工作流
浏览器自动刷新
引入文件

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注