AngularJS:Font Awesome Like Button没有在ng-show下显示

时间:2016-02-17 11:47:53

标签: javascript angularjs

我正在尝试使用类似于按钮的字体,使用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 我的挑战是,当我运行代码时,字体图标不会出现。我有什么问题?

2 个答案:

答案 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是其中一个假值,第一个条件将通过,第一个图标将会显示。