Kev*_*vin 11 angularjs ng-switch ng-repeat
我在Angular中遇到过我没想到的行为,这篇文章的目的是找出这是一个错误或是否有意,并可能解释为什么会这样.
首先看看这个Plunkr:http://plnkr.co/edit/CB7k9r?p = preview .在示例中,我创建了一个名为array的数组,其中包含三个对象条目 此外,我根据输入字段的内容(称为切换)创建了一个ng-switch.当toggle的值为1时,它应该打印前缀为"1"的数组中的所有对象名称,否则以"other"为前缀.
这不会按预期工作,它会显示错误:
Error: Argument '?' is required at assertArg
Run Code Online (Sandbox Code Playgroud)
然而,同样的例子重写(http://plnkr.co/edit/68Mfux?p=preview),列表周围有一个额外的div,ng-switch移动到这个div,ng-switch-从li移到ul(将ng-repeat和ng-switch-when分开)确实按预期工作.
有人可以解释为什么会这样吗?
Tia*_*dão 17
它是"有意的",因为它是角度如何处理ng-repeat的产物.基本上,克隆了多个标记副本(ng-repeat中的标记用作模板),并为您正在迭代的每个元素单独编译.因此,angular基本上是编译3 <li ng-switch-when='1' ....>和3 <li ng-switch-default ....>,但是在上下文中这样做 - 没有可以比较的ng-switch-on元素.
您可以通过检查生成的标记来看到这种情况:
<ul ng-switch="" on="toggle">
<!-- ngRepeat: entry in array -->
<!-- ngSwitchWhen: 1 -->
<!-- ngSwitchWhen: 1 -->
<!-- ngSwitchWhen: 1 -->
<!-- ngRepeat: entry in array -->
<!-- ngSwitchDefault: -->
<!-- ngSwitchDefault: -->
<!-- ngSwitchDefault: -->
</ul>
Run Code Online (Sandbox Code Playgroud)
两种指令 - ng-repeat和ng-switch - 都应小心处理,因为它们(例如,ng-show或ng-hide不同)会严重影响结构.第二个(工作)Plunker是要走的路 - 只能使用指令AFTER(结构方面,INSIDE)ng-switch逻辑.
| 归档时间: |
|
| 查看次数: |
11575 次 |
| 最近记录: |