- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
如何在 ng-repeat
中通过变量引用 $odd
或 $even
?我正在尝试这样做:
<ng-repeat="item in items" ng-if="$odd">these are odd{{item}}</div>
<ng-repeat="item in items" ng-if="$even">these are even {{item}}</div>
这样做:
<div ng-repeat="side in sides">
<div ng-include='template'></div>
</div>
//template
<ng-repeat="item in items" ng-if="side">these are {{side}} {{item}}</div>
//in the controller
$scope.sides = ['$odd','$even']
{{side}}
在文档中按预期生成 $odd
和 $even
文本,但所有 { {item}}
正在通过。
我试过ng-if="side"
, ng-if=side
, ng-if={{side}}
, ng-if="'side' "
.我敢肯定这只是我的菜鸟无知在起作用,它正盯着我看。
编辑:::
抱歉我没说清楚。如果我想手写整个布局,那么分配 $odd 和 $even 就足够简单了,我心软了,现在就这样做了。然而,我想做的是使用 ng-include 尽可能多地对布局的重用部分进行模板化。我的布局的一个非常简化的版本看起来像这样:
我想做的是变成这样:
<div class="outer-column1">
<div class="innercolumnA">
<div class="thumbnail" ng-repeat"thumbnail in thumbnail" ng-if"$even"></div>
</div>
<div class="innercolumnB">
<div class="thumbnail" ng-repeat"thumbnail in thumbnail" ng-if"$odd"></div>
</div>
</div>
<div class="outer-column2">
<div class="innercolumnA">
<div class="thumbnail" ng-repeat"thumbnail in thumbnail" ng-if"$even"></div>
</div>
<div class="innercolumnB">
<div class="thumbnail" ng-repeat"thumbnail in thumbnail" ng-if"$odd"></div>
</div>
</div>
像这样:
<div ng-include="outer-column" ng-repeat="outercolumn in outercolumns"></div>
//template outer-column
<div class="outer-column">
<div ng-include="inner-column" ng-init="innercolumns = [$odd,$even] " ng-repeat="innercolumn in innercolumns"></div>
</div>
//template inner-column
<div class="innercolumn" ng>
<div ng-include="'thumbnail'" ng-repeat"thumbnail in thumbnail" ng-if"innercolumn"></div>
</div>
//template thumbnail
<div class="thumbnail"></div>
问题是:如何间接引用 ng-if 的 $odd 和 $even 变量?例如,我尝试了 ng-init="sides = [$odd,$even]"并将其传递到内部列模板的 ng-repeat 中
并放置 ng-if="side"
到模板中,但是不行。
我还考虑过传递一个像 ng-if="whichSide(side)"这样的函数,它会返回 $odd 或 $even,但 $odd 和 $even 变量似乎没有在 $scope 对象上定义。 ..
但这就是我试图理解的关于 $odd 和 $even 变量并间接引用它们的精神……希望这是有道理的。该项目工作得很好,每当我进行更新时更改 10 行代码与 3 行模板化布局相比,这很烦人。谢谢!
最佳答案
$odd
和 $even
是 ng-repeat
中的可用变量。看起来您正在尝试评估字符串文字。观察以下示例并从那里为您的工作副本建模...
<div ng-app="app" ng-controller="ctrl">
<div ng-repeat="o in items" ng-if="$odd" class="odd">index: {{ $index }} value: {{ o }}</div>
<div ng-repeat="o in items" ng-if="$even" class="even">index: {{ $index }} value: {{ o }}</div>
</div>
// -- for visual demo. ng-if will work the same
.odd { background-color: dodgerblue; }
.even { background-color: tomato; }
angular.module('app', [])
.controller('ctrl', function($scope) {
$scope.items = [1, 2, 3, 4, 5];
})
JSFiddle Link - 工作演示
此外,我不完全确定您的总体目标是什么,但在我的示例中,我将类应用于样式 $even
和 $odd
以进行演示。 AngularJS 提供 ngClassOdd和 ngClassEven作为实现这一目标的替代方法。最后,如果您正在评估 $even
和 $odd
- 当然会显示所有项目。
查看 ngRepeat docs对于可用变量,您必须评估
$index
- iterator offset of the repeated element (0..length-1)$first
- true if the repeated element is first in the iterator.$middle
- true if the repeated element is between the first and last in the iterator.$last
- true if the repeated element is last in the iterator.$even
- true if the iterator position $index is even (otherwise false).$odd
- true if the iterator position $index is odd (otherwise false).
关于javascript - ng-重复 : how do I properly reference $odd or $even by variable?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32982016/
for /f "tokens=*" %%a in ('find /v ":" "%appdata%\gamelauncher\options.txt" ^| find "menu=a"') do (
我在 Javascript 中有一组全局计数器变量: var counter_0 = 0; var counter_1 = 0; var counter_2 = 0; 等等 然后我有一个 Javasc
好的,我正在阅读一些有关 RedBlackTrees 的代码。我注意到这一行“v1 = v2 = v3 = v4;”我理解类似“v1 += v2”(将 v2 添加到 v1 的当前值)和“v1 = v2
我正在为 C# 中的游戏数据加载制作一个 csv 阅读器,我想做的就是从数组(变量)的值声明一个变量,我们可以在 php 中像 $$foo 那样做。喜欢 void csvReader(string s
假设我有变量 内容为“ 123 ”和变量 b123 里面有一些文字。出于某种原因,我想使用变量 作为第二个 var 名称的一部分。像这样的东西: SET a=123 SET b123=some_tex
我对 javascript 有点陌生,我无法通过谷歌搜索找到任何内容,我正在编写一个程序,并且能够执行我所要求的操作: if (Variable == 1 或 Variable == 2 或 Vari
我发现我自己在做这种类型的 IF 语句分配。例如: if($variable == 1 || $variable == "whatever" || $variable == '492') { ...
我的虚拟 PC 在 MS-DOS 6.22 上运行时出现问题。 我需要使用变量 Date ,但我无法得到它,因为每当我尝试回显变量时,它都会显示 %variable%反而。 我在 Windows 控制
尝试运行此代码时: List list = em.createQuery("select balance b from Users where b.userName = '" + user_name.
我有一些代码,其中变量可以是 undefined、null 或正常值。无论变量是 undefined 还是 null,代码都需要做同样的事情。说有没有危险 for (var cur = this.bu
我正在编写一个批处理命令脚本,其中检查环境变量。我需要通过传递所有必需的变量来编写一个 FOR 循环,然后验证它是否已定义,如果未定义,则提示该键的值并永久设置该变量。 问题是我无法取消引用循环变量并
我知道这些是 Rails 的基础知识,但我仍然不知道 = 符号和 => 之间的全部区别以及 @some_variable 之间的区别、@@some_variable 和 :some_variable
我正在使用以下内容创建一个动态变量(PHP 术语中的“变量变量”): foo: "test1" set to-word (rejoin [foo "_result_data"]) array 5 但是
我一直在啃 PHP 套接字服务器和客户端的基础知识 here . 然后我偶然发现了这些行(摘自上面链接的第一个示例,发生在 while 中): if (false === ($buf = socket
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 9 年前。 我正在寻找一些编码来扩展我在 Java 方面的知
如何在 C++ 中从其他变量的值打印变量我只是 C++ 的新手。 在 php 中,我们可以通过其他变量的值来制作/打印一个变量。像这样。 $example = 'foo'; $foo = 'abc';
作为 Ruby on Rails 新手,我明白“@”和“:”引用有不同的含义。我看到了this post在 SO 中,其中描述了一些差异。 @ 表示实例变量(例如@my_selection) :表示别
编程新手/甚至更新。一个小的 go 程序有问题 - 不会编译带有 undefined variable 错误。代码: package main import ( "fmt" "io" "o
我知道其他一些语言,如PHP,支持“变量变量名”的概念--即,字符串的内容可以用作变量名的一部分。。我听说总的来说这不是一个好主意,但我认为它可以解决我在Python代码中遇到的一些问题。。有没有可能
我有两个版本的代码。 版本 1 Launcher.java class Launcher { public static void main(String[] args) {
我是一名优秀的程序员,十分优秀!