Angularjs处理页面闪烁的解决方法
发布时间 - 2026-01-11 00:04:50 点击率:次摘要

在使用{{}}绑定数据的时候,页面加载会出现满屏尽是{{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/107905.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
# 页面闪烁
# AngularJS页面访问时出现页面闪烁问题的解决
# AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
# Angularjs在初始化未完毕时出现闪烁问题的解决方法分析
# AngularJS 防止页面闪烁的方法
# 加载
# 就会
# 绑定
# 这个问题
# 这种情况
# 可以使用
# 可以防止
# 是一个
# 情况下
# 让人
# 还没
# 放在
# 也会
# 很难
# 下了
# 所需
# 很喜欢
# 但这
# 很长
# 所示
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Java垃圾回收器的方法和原理总结
Java类加载基本过程详细介绍
如何确保西部建站助手FTP传输的安全性?
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
jQuery 常见小例汇总
php增删改查怎么学_零基础入门php数据库操作必知基础【教程】
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
如何选择PHP开源工具快速搭建网站?
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
如何在阿里云部署织梦网站?
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
Android实现代码画虚线边框背景效果
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
如何用PHP工具快速搭建高效网站?
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
Laravel如何保护应用免受CSRF攻击?(原理和示例)
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
如何快速搭建高效WAP手机网站?
Laravel怎么在Blade中安全地输出原始HTML内容
Swift中switch语句区间和元组模式匹配
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
如何在服务器上配置二级域名建站?
Android Socket接口实现即时通讯实例代码
如何在万网利用已有域名快速建站?
,交易猫的商品怎么发布到网站上去?
Python文件操作最佳实践_稳定性说明【指导】
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
详解jQuery停止动画——stop()方法的使用
Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
使用豆包 AI 辅助进行简单网页 HTML 结构设计
怎样使用JSON进行数据交换_它有什么限制
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
Linux网络带宽限制_tc配置实践解析【教程】
如何快速生成高效建站系统源代码?
上一篇:yii中有哪些排序方法
下一篇:yii中怎么引用外部文件
上一篇:yii中有哪些排序方法
下一篇:yii中怎么引用外部文件

