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小括号“()”的多义性
Dec 03 Javascript
一个小例子解释如何来阻止Jquery事件冒泡
Jul 17 Javascript
JS实现模拟风力的雪花飘落效果
May 13 Javascript
不能不知道的10个angularjs英文学习网站
Mar 23 Javascript
vue2.0 中#$emit,$on的使用详解
Jun 07 Javascript
jQuery层级选择器_动力节点节点Java学院整理
Jul 04 jQuery
详解vue渲染从后台获取的json数据
Jul 06 Javascript
Node.js 基础教程之全局对象
Aug 06 Javascript
Vue中JS动画与Velocity.js的结合使用
Feb 13 Javascript
微信小程序常见页面跳转操作简单示例
May 01 Javascript
JS函数进阶之prototy用法实例分析
Jan 15 Javascript
vue-cil之axios的二次封装与proxy反向代理使用说明
Apr 07 Vue.js
详解如何使用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
生成缩略图
2006/10/09 PHP
学习discuz php 引入文件的方法DISCUZ_ROOT
2009/06/21 PHP
php错误级别的设置方法
2013/06/17 PHP
php中通过curl检测页面是否被百度收录
2013/09/27 PHP
PHP使用curl制作简易百度搜索
2016/11/03 PHP
通过JAVAScript实现页面自适应
2007/01/19 Javascript
映彩衣的js随笔(js图片切换效果)
2011/07/31 Javascript
自己写的兼容ie和ff的在线文本编辑器类似ewebeditor
2012/12/12 Javascript
JS 获取鼠标左右键的键值方法
2014/10/11 Javascript
Javascript数据结构与算法之列表详解
2015/03/12 Javascript
JQuery实现左右滚动菜单特效
2015/09/28 Javascript
JavaScript读二进制文件并用ajax传输二进制流的方法
2016/07/18 Javascript
Node.js开发第三方微信公众平台
2017/06/05 Javascript
基于vue2.0动态组件及render详解
2018/03/17 Javascript
Bootstrap告警框(alert)实现弹出效果和短暂显示后上浮消失的示例代码
2020/08/27 Javascript
Python中的闭包实例详解
2014/08/29 Python
python计算N天之后日期的方法
2015/03/31 Python
在python中实现对list求和及求积
2018/11/14 Python
Python设计模式之抽象工厂模式原理与用法详解
2019/01/15 Python
tensorflow mnist 数据加载实现并画图效果
2020/02/05 Python
Python修改列表值问题解决方案
2020/03/06 Python
Crocs欧洲官网:Crocs Europe
2020/01/14 全球购物
数据库连接池的工作原理
2012/09/26 面试题
What is EJB
2016/07/22 面试题
音乐教学案例
2014/01/30 职场文书
《赵州桥》教学反思
2014/02/17 职场文书
生物制药专业自我鉴定
2014/02/19 职场文书
纠风工作实施方案
2014/03/15 职场文书
公司担保书范文
2014/05/21 职场文书
公务员诚信承诺书
2014/05/26 职场文书
经营目标管理责任书
2014/07/25 职场文书
保研导师推荐信
2015/03/25 职场文书
感恩父母主题班会
2015/08/12 职场文书
《植物妈妈有办法》教学反思
2016/02/23 职场文书
利用Sharding-Jdbc进行分库分表的操作代码
2022/01/22 Java/Android
Windows server 2012 NTP时间同步的实现
2022/06/25 Servers