- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
查看:
我有一行重复,每行都有一个保存按钮来单独保存每个对象。如果没有进行任何更改,我希望禁用此按钮。
<tr ng-repeat="option in options | filter:search">
<a ng-click="save(option)" ng-disabled="isUnchanged(option)">Save</a>
</tr>
Controller :
所以我将选项对象传递给函数,我得到了它在数组中的索引位置。然后将此“选项”对象与其作为服务注入(inject)的 apiKeyOptions[index] 中的原始自身进行比较。
angular.module('PartOfApp')
.controller('PartOfAppCtrl', function( $scope, ... apiKeyOptions) {
$scope.options = apiKeyOptions;
$scope.isUnchanged = function(option) {
var index = $scope.options.indexOf(option);
//compare object to the original
if(option.value == apiKeyOptions[index].value && apiKeyOptions[index].setting == option.setting){
//then no changes have been made to this
return true;
}else{
return false;
}
出于某种原因,当任何数据发生更改时,我都会收到一个包含 100 个错误的控制台,提示 apiKeyOptions[index].value 和 apiKeyOptions[index].setting 未定义。
该应用程序运行完美,因为如果它们相同但仍然抛出
,它应该返回 true TypeError: Cannot read property 'value' of undefined
关于 apiKeyOptions[索引]
如果我 console.log(apiKeyOptions[index].value) 我没有得到未定义的值并且所有日志都正确。
我猜我违反了一些 Angular 规则,如果有人能提供帮助那就太好了。
apiKeyOptions 概述:
apiKeyOptions 是最多包含 50 个对象的数组
每个对象的形式为
{
defaultValue: boolean,
description: null,
name: String,
setting: "Default" or Boolean,
value: Boolean
}
在下面的评论后添加:如果我添加 -
console.log(index);
console.log(apiKeyOptions[index]);
对于函数$scope.isUnchanged,我得到了预期的结果示例:
13
Object {name: "LOREM IPSUM", description: null, defaultValue: false, setting: "default", value: false…}
所以索引并不总是-1。我将对象传递给函数而不是 $index 的原因是因为过滤器 |搜索,因此索引将根据搜索而变化。
已修复
如下面的答案所示。我收到一个 index = -1 错误,但它被隐藏在 100 个正确的日志输出中。
奇怪的是,这并没有阻止应用程序工作,我需要更深入地研究 ng-disabled 是如何绑定(bind)到一个值的。为了解决这个问题,我简单地将indexOf替换为
for (var i = 0; i< $scope.options.length; i++ ){
if($scope.options[i].name == option.name){
var index = i;
}
}
最佳答案
问题似乎出在传递给 $scope.isUnchanged = function(option) {
的参数上由于 ng-repeat 为每个循环创建一个新范围,我怀疑每个循环可用的“选项”将是一个新对象,并且不会引用“选项”数组。
<tr ng-repeat="option in options | filter:search">
因此,您的 isUnchanged
函数将接收参数作为新对象,因此下面的代码始终返回 -1。因为 indexOf 匹配数组中给定的参数,并且由于参数“option”是一个对象并且不引用(引用比较)数组的相同元素,因此不会找到匹配项。即 var a = {id:1};var b = [a]; b.indexOf({id:1}) === -1; b.indexOf(a) === 0;
var index = $scope.options.indexOf(option);//always be -1 in your case
// therefore apiKeyOptions[index] will always be undefined
作为解决方法,您应该将 $index 从 View 传递给 isUnchanged
。
关于javascript - AngularJs 为什么在 ng-disabled 函数上 undefined object ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26863790/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!