@zhouyy
2018-03-27T11:02:26.000000Z
字数 1867
阅读 573
Webpack
https://webpack.js.org/configuration/resolve/#resolve-extensions
新建项目,项目的目录结构说明
.├── package.json # 项目配置├── src # 源码目录│ ├── pageA.html # 入口文件a│ ├── pageB.html # 入口文件b│ ├── css/ # css资源│ ├── img/ # 图片资源│ ├── js # js&jsx资源│ │ ├── pageA.js # a页面入口│ │ ├── pageB.js # b页面入口│ │ ├── lib/ # 没有存放在npm的第三方库或者下载存放到本地的基础库,如jQuery│ ├── pathmap.json # 手动配置某些模块的路径,可以加快webpack的编译速度├── webpack.config.js # webpack配置入口
新建package.json文件,复制以下内容执行npm install
{"name": "food-safety-index-platform","version": "1.0.0","description": "food-safety-index-platform","scripts": {"test": "echo \"Error: no test specified\" && exit 1"},"author": "sloong","license": "MIT","devDependencies": {"css-loader": "^0.21.0","file-loader": "^0.8.5","style-loader": "^0.13.0","url-loader": "^0.5.7","webpack": "^1.13.1","webpack-dev-server": "^1.14.1"}}
1.下载的jquery.js 放到 src/js/lib 下(同理其他第三方库)
2.在src目录下增加 pathmap.json,手动配置某些模块的路径,可以加快webpack的编译速度
"jquery": "js/lib/jquery.js"
3.配置webpack.config.js
var webpack = require("webpack");var path = require("path");var pathMap = require('./src/pathmap.json');var srcDir = path.resolve(process.cwd(), 'src');var nodeModPath = path.resolve(__dirname, './node_modules');//from __dirname to 绝对路径 ./node_modulesmodule.exports = {entry: "./src/js/index.js",//入口js,可为数组output: {path: path.join(__dirname, "dist"),filename: "bundle.js"},module: {rules: [{test: /\.css$/, loader: 'style-loader!css-loader'}]},resolve: {extensions: ['.js',".css"],modules: [srcDir,nodeModPath],alias: pathMap// publicPath: '/'}}
4.新增index.html,引用了 dist/bundle.js
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>test avalon</title></head><body><script src="../dist/bundle.js"></script></body></html>
5.新增index.js。需要用哪个js库,就require('3rd-jslib')进来,webpack会将根据依赖项将所需的lib库打包到目标js文件中
//jquery 测试var $ = require("jquery")$("<div>这是jquery生成的</div>").appendTo("body")
6.在项目路径下,执行webpack 打包指令
webpack
7.启动webpack-dev-server
webpack-dev-server
if dont have(npm install webpack-dev-server --save-dev)