行如风 Angular 初识5

前端之家收集整理的这篇文章主要介绍了行如风 Angular 初识5前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

今天说一下关于AngularJs闪屏问题和使用对象扩充数据遍历,直接上代码

(一)、闪屏问题

首先要知道是什么原因会造成闪屏问题,大家都知道数据绑定会有2种写法(此处的2种不包括表单的数据绑定),即ng-bind{{xxx}}的写法,

比如以下代码

<div>{{name}}</div><div ng-bind=”name”></div>

这两种都可以绑定数据,但是{{name}}页面刷新时Web渲染的时候还会显示{{name}},然后当Angularjs内容被读完之后,Angular才会处理{{name}}内容,比如$scope.name=”你好”;Angular被加载之后{{name}}才会变为你好,所以会有闪屏的现象。但是用指令ng-bind=”name”不会出现闪屏,因为指令实在标签属性里不会显示页面当中,虽然这两者都是在Angular加载完成之后才会再渲染相应的内容效果却不一样。

那这样大家可能回想,那以后大家都用指令来绑定不就行了吗?但是指令是写在标签属性里,如果要绑定的名称很长{{zxcvbmdashkeqw}}或者还要在指令里面做运算+-*/..等等,这会导致标签属性过于冗余,不是理想的解决方法,所以大家可以这样写

<style>
.ng-cloak{display:none;}
</style>
<divng-app="hd"ng-cloakng-controller="ctrl"class="ng-cloak">{{name}}
</div>

class="ng-cloak"就是解决闪屏问题的关键指令,要保证style里面有对应的样式,还要保证在对应模块的标签里要有class="ng-cloak",这样就完美解决了,原理是这个模块会在Angular将这个模块渲染完之后再显示模块内的数据。J

(二)、对象扩充和数据遍历

直接撸代码

<!DOCTYPEhtml>
<html>
	<head>
		<Metacharset="UTF-8">
		<Metaname="viewport">
		<title></title>
		<style>
			.ng-cloak{display:none;}
		</style>
	</head>
	<body>
		<divng-app="hd"ng-cloakng-controller="ctrl"class="ng-cloak"><!--要想效果一样必须class名称是ng-cloak-->
			<divng-repeat="(key,value)indata">
				{{key}}--{{value}}
			</div>
			
		</div>
		
	</body>
</html>
<scripttype="text/javascript"src="js/angular.js"></script>
		<script>
			varm=angular.module('hd',[]);
			m.controller('ctrl',['$scope',function($scope){//[]里的$scope为依赖注入
			//	函数使用对象扩充
//			varobj={'name':'后盾网'};
//			angular.extend(obj,{url:'houdunwang.com',web:'后盾人'})
//			console.log(obj);
			//	数据遍历数组
//			$scope.data=[{name:'后盾网',url:'houdunwang.com'},{name:'后盾人',url:'houdunren.com'}]
//			angular.forEach($scope.data,function(v,k){
//				console.log(v,k);
//				v.url='www.'+v.url;
//			});
			//	数据遍历对象
			$scope.data={name:'后盾网',url:'houdunwang.com'};
			angular.forEach($scope.data,k){
				console.log(v,k);
			})
			
			
			
			}]);
		</script>

猜你在找的Angularjs相关文章