在使用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']); }] } })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍angular-ui-router 重新加载当前状态,包括了angular-ui-router 重新加载当前状态的使用技巧和注意事项,需要的朋友参考一下 示例 您可以使用$state.reload控制器中的方法重新加载当前状态 这是的简写(摘自官方文档的代码) 在您的状态上运行重载也会重新启动控制器并重新解析所有已解析的值。
问题内容: 我有这个模块,它将外部库与其他逻辑一起组成组件,而无需将标签直接添加到index.html中: 我注意到ES6规范是静态的,并且在TypeScript编译期间而不是在运行时进行了解析。 无论如何使其可配置,以便从CDN或本地文件夹加载file.js?如何告诉Angular 2动态加载脚本? 问题答案: 如果使用的是system.js,则可以在运行时使用: 如果您使用的是webpack,
问题内容: 我正在尝试找到一种优雅的方法来创建一个自定义的 body标签 动态类,该类可以从中轻松设置,如果未设置,则可以使用默认选项或不使用。 例: routes.js 简单标记HTML 场景: 1 -参观 登录 我应该有 一流 的身体等于 2-此时访问 寄存器 ,它将具有相同的类 3-访问 个人资料* ,身体将具有 默认 类别或 没有 默认 类别 * 您如何实现的? 问题答案: 您可以拥有一个
问题内容: 如何使用从数据库中获取的名称作为templateUrl文件名? 我已经试过了: 如果我的$ rootScope.template来自数据库查询,那似乎不起作用。不知道为什么,但是不起作用。 如果在我的控制器中执行$ rootScope.template =“ whatever.html”,则一切正常,但是,如果我从数据库中查询模板,则什么也不会发生。templateProvider中的
本文向大家介绍angular-ui-router 基本观点,包括了angular-ui-router 基本观点的使用技巧和注意事项,需要的朋友参考一下 示例 index.html script.js
问题内容: 我曾经使用过i18n。我想将服务用于模块化语言密钥作为延迟加载。我也想为此使用解决选项。 现在该怎么做?是否可以为我添加代码示例? 谢谢 问题答案: 我找到解决方案并解决我的问题。 在配置中: 在索引中: 并在: 在工厂: 并且请注意,您应该像这样在所有参数中添加和作为参数: