Foreword
上一篇简单介绍了webpack的打包功能,应该说是比较无意义的打包,对于开发人员来说,这种效率是非常低的。所以我们来点升华。
First Step
我们给第一篇例子中加个样式文件我们 style.css
body { background: yellow; }
然后修改 entry.js
require("!style-loader!css-loader!./style.css") // 载入 style.css
document.getElementById('app').innerHTML="it works";
require("./content.js");
ps: 这里就体现loader的用处了,我们先回顾一下index.html的代码
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<div id="app"></div>
<script src="bundle.js"></script>
</body>
</html>
在这里我们只引入webpack打包生成后的bundle.js,所有的js css 等都是通过这个文件被引入页面的,而不像平常我们引入 js 用 <script>标签 引入 css 用 link/<style>便签引入.
原理就是 首页 将 style.css 也看成是一个模块,然后用 css-loader 来读取它,再用 style-loader 把它插入到页面中。
所以我们还要再package.json安装 css-loader style-loader 依赖
$ cnpm install css-loader --save-dev
$ cnpm install style-loader --save-dev
安装成功后成功自动加入依赖信息
让我们跑一下
$ webpack entry.js bundle.js
刷新index.html后就能看到body被改为 yellow 了
如果每次 require CSS 文件的时候都要写 loader 前缀,是一件很繁琐的事情。我们可以根据模块类型(扩展名)来自动绑定需要的 loader。
将 entry.js 中的 require("!style-loader!css-loader!./style.css") 修改为 require("./style.css") ,(ps:我用的是webpack 2.2.1版本的,在这里它已经不允许在使用loaders 时去省略 -loader 这个后缀了,所以打包时报错,请检查你是否写成了require("!style!css!./style.css") ) 然后执行:
//为了看效果,我们可以在style.css里面把yellow换成其他颜色
$ webpack entry.js bundle.js --module-bind 'css=style-loader!css-loader'
# 有些环境下可能需要使用双引号 而且需要在感叹好前加上斜杠进行转译
$ webpack entry.js bundle.js --module-bind "css=style-loader!css-loader"
显然,这两种使用 loader 的方式,效果是一样的。
Second Step
要是每次都需要打一堆字符串去打包,简直无法忍受,所以我们需要简化,简化。。。。
webpack.config
Webpack 在执行的时候,除了在命令行传入参数,还可以通过指定的配置文件来执行。默认情况下,会搜索当前目录的 webpack.config.js 文件,这个文件是一个 node.js 模块,返回一个 json 格式的配置信息对象,或者通过 --config 选项来指定配置文件。
首先我们还是要先安装webpack依赖,之前的demo都是在全局的webpack下操作的,现在我们要在项目目录下安装webpack
$ cnpm install webpack --save-dev
成功在package.json加入依赖
然后创建一个配置文件 webpack.config.js:
#此文件不能写注释,我这里图方便,就以注释的方式进行注解了
var webpack = require('webpack'); // 引入webpack 模块
module.exports = { //commonJs模块规则写法
entry: './entry.js', //入口文件,这里指的是根目录下的entry.js作为入口文件
output: {//输出接口
path: __dirname,//项目输出的路径(__dirname为绝对路径)
filename: 'bundle.js'//文件以bundle.js输出
},
//定义了对模块的处理逻辑,这里可以用 loaders 定义了一系列的加载器,
以及一些正则。当需要加载的文件匹配test的正则时,
就会调用后面的 loader 对文件进行处理,这正是 webpack 强大的原因。
module: {
loaders: [
{test: /\.css$/, loader: 'style-loader!css-loader'}
]
}
}
详细的其他配置信息可以去官网进行查看
同时简化 entry.js 中的 style.css 加载方式:
require('./style.css')
最后运行一下
$ webpack
可以看到 webpack 通过配置文件执行的结果和上一章节通过命令行 webpack entry.js bundle.js --module-bind 'css=style-loader!css-loader' 执行的结果是一样的。
这篇就这样吧,感觉进度有点慢
webpack -> vue Component 从入门到放弃(四)
webpack -> vue Component 从入门到放弃(一)
webpack -> vue Component 从入门到放弃(三)
github源代码
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。