美文网首页
AngularJS 指令ng-if注意事项

AngularJS 指令ng-if注意事项

作者: 竿牍 | 来源:发表于2017-01-14 17:10 被阅读262次

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 中的作用域

相关文章

  • AngularJS 指令ng-if注意事项

    ng-if指令可以根据表达式的值true/false在DOM中真正生成或真正移除一个元素。如果赋值给ng-if的表...

  • AngularJs ng-if指令

    ng-if指令用于验证 ng-if=“函数或表达式” 当表达式返回布尔true时创建元素,返回false时删除该元...

  • AngularJS 常见面试问题

    AngularJS 常见面试问题 1. ng-if 跟 ng-show/hide 的区别有哪些? ng-if在后面...

  • Angular相关指令

    AngularJS 指令 本教程用到的 AngularJS 指令 : 指令 描述 ng-app 定义应...

  • AngularJS 参考手册

    AngularJS 指令 本教程用到的 AngularJS 指令 : 过滤器解析 AngularJs 过滤器。 A...

  • angularJS中$scope作用域问题

    说明: angularJS中,ng-if,ng-repeat,ng-switch,ng-view,ng-inclu...

  • AngularJS (2)

    AngularJS 指令 AngularJS 指令是扩展的 HTML 属性,带有前缀 ng-。 ng-app 指令...

  • ng-if指令

    概述 在Angular JS中,可以使用ng-if指令来控制元素是否存在。 实现细节 ng-if标签通过监控绑定的...

  • AngularJS 指令

    AngularJS 指令 背景 什么是AngularJS指令? 一、内置指令 二、自定义 概念 模块对象app,提...

  • AngularJS使用

    AngularJS实现MVC AngularJS模块化Module AngularJS指令系统 AngularJS...

网友评论

      本文标题:AngularJS 指令ng-if注意事项

      本文链接:https://www.haomeiwen.com/subject/grgebttx.html