webpack系列目录
基于webpack搭建纯静态页面型前端工程解决方案模板, 最终形态源码见github:
正文
本篇主要介绍如何集成常用的js库,以avalon 和jquery 为例,同理可扩展到其他js库。更高级的功能见后续文章。更高级的功能见后续文章
avalon 是国内的一个轻量级 MVVM js框架,只是以此为例 并不仅限于它
集成avalon
由于项目用到了Avalon这个MVVM框架,webpack是兼容多种类型的加载器(AMD,CMD),平常用的avalon.js是自带加载器,用webpack打包时avalon,只能选用avalon的shim无加载器版本,而avalon 目前只有1.4有shim的版本,且不能通过npm install,所以只好到github 下载shim版本的avalon。其中avalon1.4 有3个version,可以根据项目需要下载相应的shim版本到项目中:
- avalon.js 支持IE6+ 和现代浏览器
- avalon.modern.js 合适于IE10+ 和HTML5 标准浏览器
- avalon.mobile.js 支持移动设备(增加了Touch Event,Pointer,Event,fastclick)
基础结构和准备工作
首先得安装上npm,再其次安装webpack
新建项目,项目的目录结构说明
文件a
│ ├── pageB.html # 入口文件b
│ ├── css/ # css资源
│ ├── img/ # 图片资源
│ ├── js # js&jsx资源
│ │ ├── pageA.js # a页面入口
│ │ ├── pageB.js # b页面入口
│ │ ├── lib/ # 没有存放在npm的第三方库或者下载存放到本地的基础库,如jQuery、Zepto、avalon
│ ├── pathmap.json # 手动配置某些模块的路径,可以加快webpack的编译速度
├── webpack.config.js # webpack配置入口
新建package.json文件,复制以下内容执行npm install
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"
}
}
集成Avalon
1.下载的avalon.shim.js 放到 src/js/lib 下(同理jquery,zepto)
2.在src目录下增加 pathmap.json,手动配置某些模块的路径,可以加快webpack的编译速度
备注:其他依赖js模块同理,例如:avalon + jquery(或者zepto等等)
3.配置webpack.config.js
css-loader'}
]
},resolve: {
extensions: ['.js',"",".css"],root: [srcDir,nodeModPath],alias: pathMap,publicPath: '/'
}
}
4.新增index.html,引用了 dist/bundle.js(webpack 会解析入口文件index.js,将依赖项全部打包到bundle.js中)