Angular-Ui-Router+ocLazyLoad动态加载脚本

在大型项目中,一次性加载所有js和css会影响用户体验。通过使用Angular-Ui-Router和ocLazyLoad,可以在需要时动态加载组件的脚本,提高加载速度。ocLazyLoad是一款15K大小的Angular脚本加载器,它允许在路由渲染前通过resolve加载所需js和css,避免控制器注入问题,并且已加载的脚本会被浏览器缓存。
摘要由CSDN通过智能技术生成

在使用angular过程以前同事是采取一次性加载方式,在index页面一次性加载所有的js跟css,这种加载方式只适合教学和小型项目中,中大型不建议使用,加载速度影响到用户体验。

在使用了Ui-Router以后,我第一想法就是把每个功能组件化,在请求视图的时候再去加载该页面js和css,index页面主要加载必须文件:angular.js

于是尝试了下,这样去写,但是发现angular报错,原因是控制器没有注入主程序

后面在angular库里面发现ocLazyLoad,这是一个为angular量身定制脚本加载器,它只有15K

使用它很简单:

依次载入文件

<script src="framework/angular/angular.min.js"></script>
<script src="framework/angular-ui-router.js"></script>
<script src="framework/ocLazyLoad.min.js"></script>
<script src="framework/app.js"></script>
跟平常写路由一样只是需要多一层resolve

路由在渲染之前会执行resolve对象比如用来加载js和css,当然还有其他用处

代码:(不用担心脚本重复加载,之前加载的脚本会在浏览器做缓存)

angular.module('myRouters', ['ui.router','oc.lazyLoad'])

                .state('index', {
                    url: '/index',
                    title: ' | !',
                    views: {
                        'A': {
                            templateUrl: 'components/header/header.html',
                            controller: 'headerCtrl'
                        },
                        'C@index': {
                            templateUrl: 'components/header/h1.html',
                            controller: 'H2Ctrl'
                        }
                    },
                    resolve: {
                        loadMyCtrl: ['$ocLazyLoad', function ($ocLazyLoad) {
                            return $ocLazyLoad.load(['components/header/H2.js',
                                'components/header/header.js',
                                'components/header/h3.js',
                                'components/header/header1.css']);
                        }]
                    }
                })



 



评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值