es6+angular1.X+webpack 实现按路由功能打包项目的示例


Posted in Javascript onAugust 16, 2017

需求来源

之前使用jspm来打包项目 但是有个最大的缺点,就是只能把项目打包成一个大的js,当项目开发到后期会很大,网上找了很久也没找到合理的jspm打包方式。 所以开始调研可以打包angular项目成多个文件的工具.

调研过程

过程中看了些 vue,react配合webpack按路由功能打包的demo,感觉webpack对于打包成多个文件比较擅长。

结果

第一步 核心模块依赖加载

#core.module.js //核心模块

import 'angular-route'; //官方路由依赖
import 'oclazyLoad' //angular异步加载依赖
import CoreRouter from './core.router'
import LoginModule from '../states/login/login.module' //登入模块定义js

export default angular.module('xxx.bg',[
  'ngRoute', 
  'oc.lazyLoad', 
  LoginModule.name, 
])
.config(CoreRouter) //主要是路由配置文件

第二步 路由配置

#core.router.js //这里不是重点,只是一般的配置

import LoginRouter from '../states/login/login.route' //登入路由定义js 

function CoreRouter($routeProvider) {
  $routeProvider
    .when('/login',LoginRouter)
    .otherwise({redirectTo: '/login'});
}

CoreRouter.$inject = ['$routeProvider'];

export default CoreRouter;

第三步 异步请求路由控制器的js

#login.route.js //最重要的操作都在这里

import LoginTpl from './login.tpl.html' //模板 用webpack的raw-loader加载成文本字符串,具体配置看

let LoginRoute = {
  template  :  LoginTpl,
  controller : 'LoginCtrl', //这里只是写了一个字符串
  resolve: {
    load: ['$q','$ocLazyLoad',function ($q,$ocLazyLoad) {
      return $q((resolve) => {
        //下面这一行写法是webpack在需要的时候才下载依赖的模块,[具体看这里][2]
        require.ensure([], () => {
          //这里只是依赖了一个控制器文件,但是这个文件里面你可以import很多其他的依赖
          let module = require('./login.controller'); 
          
          //加载模块名为xxx.bg.login的模块,具体是什么作用没弄明白,请高手解答
          $ocLazyLoad.load({name: 'xxx.bg.login'}); 
          
          //promise 的成功回调,不返回出去参数也没关系,因为在login.contorller.js里面已经注册了LoginCtrl
          resolve(module.controller); 
        });
      });
    }]
  }
};
export default LoginRoute;

其他文件

#login.module.js

export default angular.module('xxx.bg.login',[]);
#login.controller.js //这就是第三步异步请求的js webpack会把这个js和它依赖到的js打包成一个js

import './login.module'
import '../../../lib/echarts/echarts.min' //随便引入了一个百度图表 比较大的js 超过100K webpack会报警,需要在配置中设置

export default angular.module('xxx.bg.login')
  //注册控制器
  .controller('LoginCtrl',['$rootScope',
    function($rootScope){
      $rootScope.theme = {name:'login-page'};
  }])
#webpack.config.js
var path = require('path')
module.exports = {
 entry: './source/com.xxx.bg/main.js', //项目入口文件
 output: {
  path: './dist/public',
  publicPath: './public/',
  filename: 'bundle.js'
 },
 resolve: {
  extensions: ['', '.js'],
  alias: {
   'src': path.resolve(__dirname, '../source')
  }
 },
 resolveLoader: {
  root: path.join(__dirname, 'node_modules'),
 },
 module: {
  loaders: [
   {
    test: /\.js$/,
    exclude: /node_modules|lib/,
    loader: 'babel-loader?stage=0',
    query: {compact: false}
   },
   {
    test: /\.html$/,
    exclude: /node_modules/,
    loader: 'raw-loader?stage=0'
   }
  ]
 }
};

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

Javascript 相关文章推荐
如何用javascript控制上传文件的大小
Oct 26 Javascript
javascript引用对象的方法
Jan 11 Javascript
一个cssQuery对象 javascript脚本实现代码
Jul 21 Javascript
用Javascript获取页面元素的具体位置
Dec 09 Javascript
AngularJS  自定义指令详解及实例代码
Sep 14 Javascript
微信小程序 加载 app-service.js 错误解决方法
Oct 12 Javascript
jQuery实现两个select控件的互移操作
Dec 22 Javascript
vue实现商品加减计算总价的实例代码
Aug 12 Javascript
JS实现头条新闻的经典轮播图效果示例
Jan 30 Javascript
微信小程序中如何使用flyio封装网络请求
Jul 03 Javascript
JS使用for in有序获取对象数据
May 19 Javascript
解决echarts图表使用v-show控制图表显示不全的问题
Jul 19 Javascript
详解如何使用webpack+es6开发angular1.x
Aug 16 #Javascript
微信小程序自定义组件
Aug 16 #Javascript
最全正则表达式总结:验证QQ号、手机号、Email、中文、邮编、身份证、IP地址等
Aug 16 #Javascript
微信小程序多列选择器range-key使用详解
Mar 30 #Javascript
jQuery取得元素标签名称小结(附代码)
Aug 16 #jQuery
微信小程序tabBar底部导航中文注解api详解
Aug 16 #Javascript
AngularJS+Bootstrap3多级导航菜单的实现代码
Aug 16 #Javascript
You might like
全国FM电台频率大全 - 11 浙江省
2020/03/11 无线电
深入了解PHP类Class的概念
2012/06/14 PHP
封装ThinkPHP的一个文件上传方法实例
2014/10/31 PHP
PHP sleep()函数, usleep()函数
2016/08/25 PHP
php基于SQLite实现的分页功能示例
2017/06/21 PHP
js资料prototype 属性
2007/03/13 Javascript
javascript获取作用在元素上面的样式属性代码
2012/09/20 Javascript
Three.js源码阅读笔记(基础的核心Core对象)
2012/12/27 Javascript
js判断字符长度及中英文数字等
2014/03/19 Javascript
JavaScript实现的encode64加密算法实例分析
2015/04/15 Javascript
解析JavaScript实现DDoS攻击原理与保护措施
2016/12/26 Javascript
js css3实现图片拖拽效果
2017/03/04 Javascript
jQuery时间验证和转换为标准格式的时间格式
2017/03/06 Javascript
Vue Socket.io源码解读
2018/02/07 Javascript
详解使用jQuery.i18n.properties实现js国际化
2018/05/04 jQuery
JS中的变量作用域(console版)
2020/07/18 Javascript
jQuery实现鼠标拖动图片功能
2021/03/04 jQuery
[51:22]Fnatic vs IG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
Python实现在tkinter中使用matplotlib绘制图形的方法示例
2018/01/18 Python
python爬取足球直播吧五大联赛积分榜
2018/06/13 Python
flask应用部署到服务器的方法
2019/07/12 Python
PyCharm中Matplotlib绘图不能显示UI效果的问题解决
2020/03/12 Python
解决在keras中使用model.save()函数保存模型失败的问题
2020/05/21 Python
Django+RestFramework API接口及接口文档并返回json数据操作
2020/07/12 Python
python中如何设置代码自动提示
2020/07/15 Python
使用Python通过oBIX协议访问Niagara数据的示例
2020/12/04 Python
荷兰最大的儿童服装店:The Kids Republic
2019/04/13 全球购物
Farfetch美国:奢侈品牌时尚购物平台
2019/05/02 全球购物
美国最佳选择产品网站:Best Choice Products
2019/05/27 全球购物
幼儿园实习自我鉴定
2013/12/15 职场文书
服务行业口号
2014/06/11 职场文书
中国梦演讲稿3分钟
2014/08/19 职场文书
我们的节日中秋活动方案
2014/08/19 职场文书
MySQL系列之六 用户与授权
2021/07/02 MySQL
解决Laravel使用验证时跳转到首页的问题
2021/11/17 PHP
Mysql外键约束的创建与删除的使用
2022/03/03 MySQL