Angular.js中处理页面闪烁的方法详解


Posted in Javascript onMarch 09, 2017

前言

大家在使用{{}}绑定数据的时候,页面加载会出现满屏尽是{{xxx}}的情况。数据还没响应,但页面已经渲染了。这是因为浏览器和angularjs渲染页面都需要消耗一定的时间,这个间隔可能很小,甚至让人感觉不到,这种情况一切正常,但这个时间也可能很长,这时候用户可能会看到满屏尽是{{xxxx}}。这种情况被叫做“Flash Of Unrendered Content (FOUC)(K)?and is always unwanted.”。

问题

为了图方便,我们很喜欢使用下面的做法

<div>
 {{name}}
 </div>

但这也为满屏尽是{{}}埋下了坑。当接口,网络响应速度够快的情况下,很难发现这个问题,但放在移动端4g或者网络环境更差的情况下,这个问题就会频发。

解决办法

1、ng-cloak

该指令是angularjs的内置的指令,它的作用是隐藏所有被它包含的元素。在浏览器加载和编译渲染完成后,angularjs会自动删除ngCloak元素属性,这样这个元素就会变为可见的。

<div ng-cloak>
 {{name}}
 </div>

2、ng-bind

该指令是angularjs内置的用于绑定页面数据的指令。可以使用该指令代替{{}}的方式绑定数据到页面上。使用ng-bind可以防止未被渲染的{{}}展示给用户。如下所示:

<div ng-bind="name"> 
 </div>

3、resolve

当使用routes路由的时候,resolve可以防止我们在route路由被完全加载之前获取我们需要加载的数据,当数据被加载成功之后,路由再改变而页面也会呈现给用户,数据没有加载成功route不会改变。

可以参考:https://3water.com/article/80523.htm

angular.module('myApp', ['ngRoute'])
.config(function($routeProvider) {
 $routeProvider
 .when('/account', {
 controller: 'AccountCtrl',
 templateUrl: 'views/account.html',
 resolve: {
 // We specify a promise to be resolved
 account: function($q) {
 var d = $q.defer();
 $timeout(function() {
 d.resolve({
 id: 1,
 name: 'Ari Lerner'
 })
 }, 1000);
 return d.promise;
 }
 }
 })
});

resolve 项需要一个key/value对象,key是resolve依赖的名称,value可以是一个字符串(as a service)或者一个返回依赖的方法。

resolve is very useful when the resolve value returns a promise that becomes resolved or rejected.

当路由加载的时候,resolve参数里的keys可以作为可注入的依赖:

ngular.module('myApp')
.controller('AccountCtrl', 
 function($scope, account) {
 $scope.account = account;
});

我们同样可以使用resolve key传递$http方法返回的结果,as $http returns promises from it's method calls:

angular.module('myApp', ['ngRoute'])
.config(function($routeProvider) {
 $routeProvider
 .when('/account', {
 controller: 'AccountCtrl',
 templateUrl: 'views/account.html',
 resolve: {
 account: function($http) {
 return $http.get('http://example.com/account.json')
 }
 }
 })

推荐定义一个独立的service的方式来使用resolve key,并且使用service来相应返回所需的数据(这种方式更容易测试)。要这样处理的话,我们需要创建一个service:

首先,看一下accountService,

angular.module('app')
.factory('accountService', function($http, $q) {
 return {
 getAccount: function() {
 var d = $q.defer();
 $http.get('/account')
 .then(function(response) {
 d.resolve(response.data)
 }, function err(reason) {
 d.reject(reason);
 });
 return d.promise;
 }
 }
})

定义好service之后我们就可以使用这个service来替换上面代码中直接调用$http的方式了:

ngular.module('myApp', ['ngRoute'])
.config(function($routeProvider) {
 $routeProvider
 .when('/account', {
 controller: 'AccountCtrl',
 templateUrl: 'views/account.html',
 resolve: {
 // We specify a promise to be resolved
 account: function(accountService) {
 return accountService.getAccount()
 }
 }
 })

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript 获取iframe里页面中元素值的方法
Feb 17 Javascript
jsp网页搜索结果中实现选中一行使其高亮
Feb 17 Javascript
浅谈jQuery的offset()方法及示例分享
Jul 17 Javascript
深入剖析JavaScript面向对象编程
Jul 12 Javascript
深入理解JS正则表达式---分组
Jul 18 Javascript
Vue键盘事件用法总结
Apr 18 Javascript
JS判断非空至少输入两个字符的简单实现方法
Jun 23 Javascript
在vue项目中安装使用Mint-UI的方法
Dec 27 Javascript
react-native使用leanclound消息推送的方法
Aug 06 Javascript
关于JSON解析的实现过程解析
Oct 08 Javascript
Object.keys() 和 Object.getOwnPropertyNames() 的区别详解
May 21 Javascript
jQuery实现简单三级联动效果
Sep 05 jQuery
jQuery插件HighCharts实现的2D对数饼图效果示例【附demo源码下载】
Mar 09 #Javascript
JS实现课堂随机点名和顺序点名
Mar 09 #Javascript
JavaScript实现两个select下拉框选项左移右移
Mar 09 #Javascript
js实现年月日表单三级联动
Apr 17 #Javascript
js实现3D图片展示效果
Mar 09 #Javascript
JavaScript实现左右下拉框动态增删示例
Mar 09 #Javascript
less简单入门(CSS 预处理语言)
Mar 08 #Javascript
You might like
解析php安全性问题中的:Null 字符问题
2013/06/21 PHP
Codeigniter中mkdir创建目录遇到权限问题和解决方法
2014/07/25 PHP
php通过正则表达式记取数据来读取xml的方法
2015/03/09 PHP
Laravel 5框架学习之路由、控制器和视图简介
2015/04/07 PHP
PHP生成唯一订单号的方法汇总
2015/04/16 PHP
Yii2.0表关联查询实例分析
2016/07/18 PHP
laravel框架模型和数据库基础操作实例详解
2020/01/25 PHP
广告切换效果(缓动切换)
2009/05/27 Javascript
Prototype RegExp对象 学习
2009/07/19 Javascript
jquery 页面全选框实践代码
2010/04/02 Javascript
setTimeout的延时为0时多个浏览器的区别
2012/05/23 Javascript
js实现幻灯片效果(基于jquery插件)
2013/11/05 Javascript
鼠标左键单击冲突的问题解决方法(防止冒泡)
2014/05/14 Javascript
jQuery中:enabled选择器用法实例
2015/01/04 Javascript
JS+Canvas 实现下雨下雪效果
2016/05/18 Javascript
分享jQuery封装好的一些常用操作
2016/07/28 Javascript
import与export在node.js中的使用详解
2017/09/28 Javascript
关于vue中watch检测到不到对象属性的变化的解决方法
2018/02/08 Javascript
layDate插件设置开始和结束时间
2018/11/15 Javascript
JavaScript基于遍历操作实现对象深拷贝功能示例
2019/03/05 Javascript
layui监听单元格编辑前后交互的例子
2019/09/16 Javascript
javascript中可能用得到的全部的排序算法
2020/03/05 Javascript
python网络爬虫之如何伪装逃过反爬虫程序的方法
2017/11/23 Python
Python中return self的用法详解
2018/07/27 Python
对Python3中列表乘以某一个数的示例详解
2019/07/20 Python
python实现拼接图片
2020/03/23 Python
整理HTML5中表单的常用属性及新属性
2016/02/19 HTML / CSS
Html5实现文件异步上传功能
2017/05/19 HTML / CSS
amaze ui 的使用详细教程
2020/08/19 HTML / CSS
感恩母亲节活动方案
2014/03/04 职场文书
餐厅感恩节活动策划方案
2014/10/11 职场文书
初中班主任心得体会
2016/01/07 职场文书
2019升学宴主持词范本5篇
2019/10/09 职场文书
导游词之嵊泗列岛
2019/10/30 职场文书
解决pytorch 损失函数中输入输出不匹配的问题
2021/06/05 Python
Java 写一个简单的图书管理系统
2022/04/26 Java/Android