我正在尝试使用类似于按钮的字体,使用ng-show对布尔值为true或false。 这是我的索引中的代码
<p ng-controller="DivCtrl2" style="background-color:red">
Here is red
<div ng-show="hasLikedUser == false" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-o-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
<div ng-show="hasLikedUser == true" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
</p>
以下是我的控制器文件中的代码:
.controller('DivCtrl2', function($scope) {
$scope.toggleLikeUserPage = function()
{
if($scope.hasLikedUser){
$scope.hasLikedUser = false;
alert("This is false");
} else{
$scope.hasLikedUser = true;
alert("This is true");
}
}
这是我制作的插件演示 https://plnkr.co/edit/Zhxmmmypkypd95gXYrzx?p=preview 我的挑战是,当我运行代码时,字体图标不会出现。我有什么问题?
答案 0 :(得分:1)
您只需将ng-show
语句从ng-show="hasLikedUser == false"
更改为ng-show="!hasLikedUser"
,将ng-show="hasLikedUser == true"
更改为ng-show="hasLikedUser"
。您的模板如下:
<div ng-show="!hasLikedUser" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-o-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
<div ng-show="hasLikedUser" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
您不需要测试hasLikedUser
是否等于布尔表达式,因为是布尔表达式。
答案 1 :(得分:0)
最初hasLikedUser未设置,因此未定义,因此== true或== false检查都不会通过。改变你的条件来检查真实或虚假:
<div ng-show="!hasLikedUser" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-o-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
<div ng-show="hasLikedUser" class="tab-item" ng-click="toggleLikeUserPage()">
<i class="fa fa-thumbs-up" style="font-size: 2em; float:left; padding-left: 16px; margin-top:12px " ></i>
</div>
由于undefined是其中一个假值,第一个条件将通过,第一个图标将会显示。