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

发布时间 - 2026-01-11 00:04:44    点击率:

前言

大家在使用{{}}绑定数据的时候,页面加载会出现满屏尽是{{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://www./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()
 }
 }
 })

总结

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


# angularjs  # 页面闪烁  # 闪烁  # ng  # if  # AngularJS页面访问时出现页面闪烁问题的解决  # Angularjs在初始化未完毕时出现闪烁问题的解决方法分析  # AngularJS使用ng-Cloak阻止初始化闪烁问题的方法  # 加载  # 就会  # 绑定  # 这个问题  # 这种情况  # 可以使用  # 可以防止  # 是一个  # 情况下  # 让人  # 还没  # 放在  # 也会  # 很难  # 下了  # 所需  # 很喜欢  # 但这  # 很长  # 所示 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  Laravel怎么调用外部API_Laravel Http Client客户端使用  Laravel storage目录权限问题_Laravel文件写入权限设置  Laravel定时任务怎么设置_Laravel Crontab调度器配置  b2c电商网站制作流程,b2c水平综合的电商平台?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  canvas 画布在主流浏览器中的尺寸限制详细介绍  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  javascript日期怎么处理_如何格式化输出  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  如何在Tomcat中配置并部署网站项目?  网站建设要注意的标准 促进网站用户好感度!  Python高阶函数应用_函数作为参数说明【指导】  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Laravel如何使用.env文件管理环境变量?(最佳实践)  Laravel如何处理文件下载请求?(Response示例)  IOS倒计时设置UIButton标题title的抖动问题  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何构建满足综合性能需求的优质建站方案?  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何用已有域名快速搭建网站?  Linux后台任务运行方法_nohup与&使用技巧【技巧】  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  如何在阿里云虚拟主机上快速搭建个人网站?  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  南京网站制作费用,南京远驱官方网站?  如何获取免费开源的自助建站系统源码?  如何在IIS中新建站点并解决端口绑定冲突?  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  5种Android数据存储方式汇总  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  如何获取PHP WAP自助建站系统源码?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  Python进程池调度策略_任务分发说明【指导】  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  Laravel如何集成Inertia.js与Vue/React?(安装配置)  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  jQuery validate插件功能与用法详解  如何生成腾讯云建站专用兑换码?  深圳网站制作平台,深圳市做网站好的公司有哪些?  潮流网站制作头像软件下载,适合母子的网名有哪些?  音响网站制作视频教程,隆霸音响官方网站?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  EditPlus中的正则表达式 实战(2)