先看:Webpack入门(一)
Loaders
Loaders
是 webpack
提供的最激动人心的功能之一了。通过使用不同的 loader
,webpack
有能力调用外部的脚本或工具,实现对不同格式的文件的处理,比如说分析转换scss
为css
,或者把下一代的JS文件(ES6,ES7)转换为现代浏览器兼容的JS文件,对React
的开发而言,合适的Loaders
可以把React
的中用到的JSX
文件转换为JS
文件。
Loaders
需要单独安装并且需要在webpack.config.js
中的modules
关键字下进行配置。
Loaders
的配置包括以下几方面:
-
test
:一个用以匹配loaders所处理文件的拓-
展名的正则表达式(必须) -
loader
:loader的名称(必须) -
include/exclude
:手动添加必须处理的文件(文件夹)或屏蔽不需要处理的文件(文件夹)(可选); -
query
:为loaders提供额外的设置选项(可选)
不过在配置loader
之前,我们把Greeter.js
里的问候消息放在一个单独的JSON
文件里,并通过合适的配置使Greeter.js
可以读取该JSON
文件的值,各文件修改后的代码如下:
在app
文件夹中创建带有问候信息的JSON
文件(命名为config.json
)
{
"greetText": "Hi there and greetings from JSON!"
}
更新后的Greeter.js
var config = require('./config.json');
module.exports = function() {
var greet = document.createElement('div');
greet.textContent = config.greetText;
return greet;
};
注: 由于webpack3./webpack2.已经内置可处理JSON文件,这里我们无需再添加webpack1.*需要的json-loader。在看如何具体使用loader之前我们先看看Babel是什么?
Babel
Babel其实是一个编译JavaScript的平台,它可以编译代码帮你达到以下目的:
- 让你能使用最新的JavaScript代码(ES6,ES7...),而不用管新标准是否被当前使用的浏览器完全支持;
- 让你能使用基于JavaScript进行了拓展的语言,比如React的JSX;
Babel的安装与配置
Babel
其实是几个模块化的包,其核心功能位于称为babel-core
的npm
包中,webpack
可以把其不同的包整合在一起使用,对于每一个你需要的功能或拓展,你都需要安装单独的包(用得最多的是解析Es6
的babel-env-preset
包和解析JSX
的babel-preset-react
包)。
我们先来一次性安装这些依赖包
// npm一次性安装多个依赖模块,模块之间用空格隔开
npm install --save-dev babel-core babel-loader babel-preset-env babel-preset-react
在webpack
中配置Babel
的方法如下:
module.exports = {
devtool: 'eval-source-map',
entry: __dirname + "/app/main.js",//已多次提及的唯一入口文件
output: {
path: __dirname + "/public",//打包后的文件存放的地方
filename: "bundle.js"//打包后输出文件的文件名
},
devServer: {
contentBase: "./public",//本地服务器所加载的页面所在的目录
historyApiFallback: true,//不跳转
inline: true//实时刷新
},
module: {
rules: [
{
test: /(\.jsx|\.js)$/,
use: {
loader: "babel-loader",
options: {
presets: [
"env", "react"
]
}
},
exclude: /node_modules/
}
]
}
};
现在你的webpack
的配置已经允许你使用ES6以及JSX的语法了。继续用上面的例子进行测试,不过这次我们会使用React,记得先安装 React
和 React-DOM
。
npm install --save react react-dom
接下来我们使用ES6的语法,更新Greeter.js并返回一个React组件。
//Greeter,js
import React, {Component} from 'react'
import config from './config.json';
class Greeter extends Component{
render() {
return (
{config.greetText}
);
}
}
export default Greeter
修改main.js如下,使用ES6的模块定义和渲染Greeter模块。
// main.js
import React from 'react';
import {render} from 'react-dom';
import Greeter from './Greeter';
render( , document.getElementById('root'));
重新使用npm start
打包,如果之前打开的本地服务器没有关闭,你应该可以在localhost:8080下看到与之前一样的内容,这说明react和es6被正常打包了。
Webpack的强大功能
生成Source Maps(使调试更容易)
开发总是离不开调试,方便的调试能极大的提高开发效率,不过有时候通过打包后的文件,你是不容易找到出错了的地方,对应的你写的代码的位置的,Source Maps
就是来帮我们解决这个问题的。
通过简单的配置,webpack
就可以在打包时为我们生成的source maps
,这为我们提供了一种对应编译文件和源文件的方法,使得编译后的代码可读性更高,也更容易调试
原文地址:https://www.jianshu.com/p/42e11515c10f