全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解webpack 如何集成第三方js库

webpack系列目录

webpack 系列 二:webpack 介绍&安装

webpack 系列 三:webpack 如何集成第三方js库

webpack 系列 四:webpack 多页面支持 & 公共组件单独打包

webpack 系列 五:webpack Loaders 模块加载器

webpack 系列 六:前端项目模板-webpack+gulp实现自动构建部署

基于webpack搭建纯静态页面型前端工程解决方案模板, 最终形态源码见github: https://github.com/ifengkou/webpack-template

正文

本篇主要介绍如何集成常用的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版本到项目中:

  1. avalon.js 支持IE6+ 和现代浏览器
  2. avalon.modern.js 合适于IE10+ 和HTML5 标准浏览器
  3. avalon.mobile.js 支持移动设备(增加了Touch Event,Pointer,Event,fastclick)

基础结构和准备工作

首先得安装上npm,再其次安装webpack

npm install webpack -g

新建项目,项目的目录结构说明

.
├── package.json  # 项目配置
├── src   # 源码目录
│ ├── pageA.html  # 入口文件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

{
 "name": "webpack-template",
 "version": "1.0.0",
 "description": "webpack-template"
 "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"
 }
}

集成Avalon

1.下载的avalon.shim.js 放到 src/js/lib 下(同理jquery,zepto)

2.在src目录下增加 pathmap.json,手动配置某些模块的路径,可以加快webpack的编译速度

{
"avalon": "js/lib/avalon.shim.js"
}

备注:其他依赖js模块同理,例如:avalon + jquery(或者zepto等等)

{
"jquery": "js/lib/jquery-1.12.4.js",
"avalon": "js/lib/avalon.shim.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');
module.exports = {
entry: "./src/js/index.js",//入口js,可为数组
output: {
 path: path.join(__dirname, "dist"),
 filename: "bundle.js"
},
module: {
 loaders: [
 {test: /\.css$/, loader: 'style-loader!css-loader'}
 ]
},
resolve: {
 extensions: ['.js',"",".css"],
 root: [srcDir,nodeModPath],
 alias: pathMap,
 publicPath: '/'
}
}

4.新增index.html,引用了 dist/bundle.js(webpack 会解析入口文件index.js,将依赖项全部打包到bundle.js中)

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>test avalon</title>
</head>
<body>
<div ms-controller="avalonCtrl">
<h1>{{name}}</h1>
</div>
<script src="../dist/bundle.js"></script>
</body>
</html>

5.新增index.js。需要用哪个js库,就require('3rd-jslib')进来,webpack会将根据依赖项将所需的lib库打包到目标js文件中

var avalon = require('avalon');
avalon.define({
$id: "avalonCtrl",
name: "Hello Avalon!"
});
//jquery 测试
var $ = require("jquery")
$("<div>这是jquery生成的</div>").appendTo("body")

6.在项目路径下,执行webpack 打包指令

$ webpack

7.启动webpack-dev-server,访问http://localhost:8080/webpack-dev-server/src/index.html

$ webpack-dev-server

OK ,顺利集成

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# webpack  # 第三方js  # 引用第三方js  # 引入第三方js  # webpack+vue-cli项目中引入外部非模块格式js的方法  # webpack打包js的方法  # webpack+vue.js快速入门教程  # webpack+vue.js实现组件化详解  # Webpack 4如何动态切割JS注入文件名详解  # 加载  # 为例  # 第三方  # 这是  # 放在  # 所需  # 是国内  # 自带  # 可以根据  # 准备工作  # 会将  # 可为  # 装上  # 需要用  # 大家多多  # 扩展到  # 增加了  # 多页  # 新建项目  # 得安 


相关文章: 宝塔新建站点为何无法访问?如何排查?  建站OpenVZ教程与优化策略:配置指南与性能提升  如何在IIS中配置站点IP、端口及主机头?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  ,有什么在线背英语单词效率比较高的网站?  如何快速生成ASP一键建站模板并优化安全性?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  建站之星图片链接生成指南:自助建站与智能设计教程  如何在腾讯云服务器快速搭建个人网站?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  建站之星如何实现PC+手机+微信网站五合一建站?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  Python路径拼接规范_跨平台处理说明【指导】  C++如何编写函数模板?(泛型编程入门)  股票网站制作软件,网上股票怎么开户?  建站之星后台管理系统如何操作?  如何在西部数码注册域名并快速搭建网站?  网站代码制作软件有哪些,如何生成自己网站的代码?  油猴 教程,油猴搜脚本为什么会网页无法显示?  建站org新手必看:2024最新搭建流程与模板选择技巧  宿州网站制作公司兴策,安徽省低保查询网站?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  如何快速搭建高效香港服务器网站?  如何在阿里云虚拟服务器快速搭建网站?  如何用VPS主机快速搭建个人网站?  七夕网站制作视频,七夕大促活动怎么报名?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  建站主机系统SEO优化与智能配置核心关键词操作指南  如何选择高效稳定的ISP建站解决方案?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  如何用PHP快速搭建CMS系统?  如何选择适合PHP云建站的开源框架?  建站之星免费模板:自助建站系统与智能响应式一键生成  如何安全更换建站之星模板并保留数据?  如何配置支付宝与微信支付功能?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  如何获取上海专业网站定制建站电话?  建站之星Pro快速搭建教程:模板选择与功能配置指南  网站制作报价单模板图片,小松挖机官方网站报价?  高防服务器租用如何选择配置与防御等级?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  代刷网站制作软件,别人代刷火车票靠谱吗?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  建站主机选购指南:核心配置与性价比推荐解析  家庭建站与云服务器建站,如何选择更优?  h5在线制作网站电脑版下载,h5网页制作软件?  长沙做网站要多少钱,长沙国安网络怎么样?  制作销售网站教学视频,销售网站有哪些? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。