0x001 概述
上一章讲的是样式装载相关的loader,这一章见得是脚本加载相关的loader
0x002 环境配置
$ mkdir 0x012-transliling-loader
$ cd 0x012-transliling-loader
$ npm init -y
$ npm install --save-dev webpack
$ touch ./src/index.js
$ vim webpack.config.js
// ./webpack.config.js
const path = require('path');
module.exports = {
entry : {
'index': ['./src/index.js'],
},
output: {
path : path.join(__dirname, 'dist'),
filename: '[name].bundle.js'
}
;
0x003 栗子1-babel-laoder
加载es6
-
安装依赖
$ cnpm install --save-dev babel-loader babel-core babel-preset-env
-
修改配置
const path = require('path'); module.exports = { entry : { 'index': ['./src/index.js'], }, output: { path : path.join(__dirname, 'dist'), filename: '[name].bundle.js' }, module: { rules: [ { test : /\.js$/, exclude: /node_modules/, use : { loader: "babel-loader" } } ] } } ;
-
添加
babel
配置文件$ vim ./.babelrc // ./.babelrc { "presets": ["es2015"] }
-
使用
es6
编写脚本$ vim ./src/index.js // ./src/index.js let sayHello = () => { console.log('hello webpack') } sayHello();
-
打包并查看结果
// ./dist/index.bundle.js /***/ }), /* 1 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; var sayHello = function sayHello() { console.log('hello webpack'); }; sayHello(); /***/ }) /******/ ]);
可以看到,
es6
语法被自动转化成了es5
更多配置请查阅webpack关于babel-loader章节
0x004 栗子2-awesome-typescript-loader
加载typescript
-
安装依赖
$ cnpm install --save-dev awesome-typescript-loader
-
修改配置
const path = require('path'); module.exports = { entry : { 'index': ['./src/index.ts'], }, output : { path : path.join(__dirname, 'dist'), filename: '[name].bundle.js' }, resolve: { extensions: ['.ts', '.tsx', '.js', '.jsx'] }, module : { rules: [ { test : /\.tsx?$/, loader: 'awesome-typescript-loader' } ] } } ;
-
添加
typescript
的配置$ vim ./tsconfig.json // ./tsconfig.json { "compilerOptions": { "noImplicitAny": true, "removeComments": true }, "awesomeTypescriptLoaderOptions": { /* ... */ } }
-
编写
index.ts
class Greeter { greeting: string; constructor(message: string) { this.greeting = message; } greet() { return "Hello, " + this.greeting; } } let greeter = new Greeter("world");
-
编译并查看结果
/* 1 */ /***/ (function(module, exports) { var Greeter = (function () { function Greeter(message) { this.greeting = message; } Greeter.prototype.greet = function () { return "Hello, " + this.greeting; }; return Greeter; }()); var greeter = new Greeter("world"); /***/ }) /******/ ]);
可以看出,
typescript
被自动转化成了js
其他更多配置,请查阅awesome-typescript-loader相关说明
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。