gpt4 book ai didi

javascript - AngularJS 中的字符串比较

转载 作者:数据小太阳 更新时间:2023-10-29 06:01:23 25 4
gpt4 key购买 nike

我正在尝试比较 AngularJS 中的两个字符串,并且我在网上看到了示例。据我了解,你可以使用angular.equals(str1, str2),你可以使用===,你可以使用==,如果你确定两者都是字符串......

我已经尝试了所有三个,但我没有得到结果。我所做的一定有问题,但我不知道是什么。

当我运行代码时,会调用 inc1() 函数。第一个警报出现“inc1 called”。但是第二个警报“Inside for loop”只执行一次。它应该执行两次,不是吗?

并且 if(condition) 中的警报根本不执行。如果我删除“if” block ,则“Inside for loop”警报会运行两次。

如果有人能告诉我我在这里做错了什么,我将不胜感激。我使用过 angular.equals()、=== 和 ==,但每次都会发生同样的事情。

HTML 和 AngularJS 代码是这样的:

HTML:

<a class="tab-item" ng-repeat = "x in items" ng-if="name==x.names" ng-click="inc1(name)">
<i class="icon ion-thumbsup"></i>
Like
</a>

AngularJS:

$rootScope.items = [
{ id: 1, names: 'Dolphin', image: 'dolphin.jpg'}, { id: 2, names: 'Donkey', image: 'donkey.jpg'}];

$scope.inc1 = function(name) {

alert("inc1 called");
for(var i=0;i<$rootScope.items.length;i++)
{
alert("Inside for loop");
if (name === $rootScope.items.names[i])
{
alert("If condition satisfied");
}
}
}

//说,名字是'Dolphin'

最佳答案

你正在遍历错误的节点:)

for(var i=0;i<$rootScope.items.length;i++)
{
alert("Inside for loop");
if (name === $rootScope.items[i].names) // you iterate over items, not names, which it an Json property inside item
{
alert("If condition satisfied");
}
}

关于javascript - AngularJS 中的字符串比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30995343/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com