欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angular.JS中指令ng-if的注意事项小结

程序员文章站 2022-06-24 17:00:05
前言 ng-if指令可以根据表达式的值true/false在dom中真正生成或真正移除一个元素。如果赋值给ng-if的表达式的值是false,那对应的元素将会从dom中移...

前言

ng-if指令可以根据表达式的值true/false在dom中真正生成或真正移除一个元素。如果赋值给ng-if的表达式的值是false,那对应的元素将会从dom中移除,否则对应元素的一个克隆将被重新插入dom中。

ng-if同ng-show和ng-hide指令最本质的区别是,它不是通过css显示或隐藏dom节点,而是真正生成或移除节点。

当一个元素被ng-if从dom中移除,同它关联的作用域也会被销毁。而且当它重新加入dom中时,会通过原型继承从它的父作用域生成一个新的作用域。

这样会导致,在 ng-if 中用基本变量绑定 ng-model ,并在外层 div 中把此 model 绑定给另一个显示区域,内层改变时,外层不会同步改变,因为此时已经是两个变量了。

示例代码:

<p>{{name}}</p>

<div ng-if="true">

<input type="text" ng-model="name" />

</div>

ng-show 不存在此问题,因为它不自带一级作用域。

避免这类问题出现的办法是,始终将页面中的元素绑定到对象的属性(data.x)而不是直接绑定到基本变量(x)上。详见 angularjs 中的作用域

总结

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