javascript - Angularjs 在 ng-repeat 中显示和隐藏按钮

标签 javascript angularjs angularjs-ng-repeat

我有一个列表,它使用 ng-repeat 填充屏幕。 每行都有一个按钮供用户单击以选择该行。 通常您会使用单选按钮,但用户想要按钮切换。

我真正想要的是显示第一个按钮(在第一次显示列表时隐藏第二个按钮),在用户点击第一个按钮选择特定行后,我想隐藏第一个按钮并显示第二个按钮. 2 个按钮有不同的 ID、文本、样式。 所以对于用户来说,就像在选择后更改按钮的外观一样。

我尝试在函数 populateFareOption(row.col3.value, row.col4.value) 中设置 showfarebut1/showfarebut2 范围变量在 Controller 中,但所有行在单击第一个按钮后都有第二个按钮。

任何想法或代码片段..将不胜感激。

HTML

<tr ng-repeat="row in rowList">
    <td> {{row.col1.value}}</td>

    <td>
        <span class="price">PRICE:&nbsp;
            <strong class="amount">{{row.col2.value}}</strong>
        </span>

        <button id="btnXX1" ng-show="showfarebut1" type="button" class="btn pull-right" ng-click="populateFareOption(row.col3.value,row.col4.value)">

            <span class="text pull-left" name="fareOption" ng-model="travelCardForm.colOption" value="{{row.col3.value}}">Select</span>
            <i class="icon-placeholder"></i>
        </button> 

        <button id="btnXX2" ng-show="showfarebut2" type="button" class="btn pull-right">
            <span class="text pull-left">Selected</span>
            <i class="selected-icon pull-right"></i>
        </button>
    </td> 
</tr>

Controller

    $scope.showfarebut1=true;
    $scope.showfarebut2=false;

    $scope.populateFareOption = function(x,y){
         cardForm.fareOption.value=x;
         cardForm.productCode.value=y;
         $scope.showfarebut1=false;
         $scope.showfarebut2=true;
       }

最佳答案

在您的示例中,您在所有行中共享了 showfarebut1showfarebut2,这会导致单击一个按钮会影响所有行。您应该使用绑定(bind)到当前行的内容:row.showfarebut1row.showfarebut2

但是,有一种更有效的方法来制作切换按钮。您可以根据记录的状态重复使用相同的按钮并设置类和文本。这是一个简单的例子:

HTML

<ul class="list-group" ng-controller="ctrl">
  <li class="list-group-item" ng-repeat="row in rowList">
    <span>{{row.col1.value}}</span>
    <span>{{row.col2.value}}</span>
    <button type="button" ng-click="row.selected=!row.selected" class="pull-right btn btn-xs">
      <span ng-class="{'glyphicon':true, 'glyphicon-ok':row.selected, 'glyphicon-plus':!row.selected}"></span>
      {{row.selected?'Selected':''}}
    </button>
  </li>
</ul>

您可以使用 ng-class指令来切换类和条件,例如 {{row.selected?'Selected':''}} 来切换按钮的文本。

JavaScript

angular.module('app', []).
  controller('ctrl', function($scope) {
    $scope.rowList = [{
      col1: { value: 'r1c1'},
      col2: {value: 'r1c2'}
    }, {
      col1: {value: 'r2c1'},
      col2: {value: 'r2c2'}
    }, {
      col1: {value: 'r3c1'},
      col2: {value: 'r3c2'}
    }];
  });

你甚至不需要一些特殊的功能来选择一个项目,你可以直接在ng-click中做一些简单的事情。

截图

enter image description here

笨蛋: http://plnkr.co/edit/ZFRIWOe2HxMq8K11FBk4?p=preview


编辑(改编版):

HTML

<table ng-controller="ctrl" class="table">
  <tr ng-repeat="row in rowList">
    <td>{{row.col1.value}}</td>
    <td>
      <span class="price">PRICE:&nbsp;
        <strong class="amount">{{row.col2.value}}</strong>
      </span>
      <button id="btn{{$index}}"  type="button" class="btn pull-right" ng-click="select(row)">
        <span class="text pull-left" name="fareOption" value="{{row.col3.value}}">{{row.selected?'Selected':'Select'}}</span>
        <i ng-class="{'icon-placeholder':!row.selected, 'selected-icon':row.selected, 'pull-right':row.selected}"></i>
      </button>
    </td> 
  </tr>
</table>

JavaScript

angular.module('app', []).
  controller('ctrl', function($scope) {
    $scope.rowList = [{
      col1: {value: 'Orange'},
      col2: {value: '10'},
      col3: {value: 'x1'},
      col4: {value: 'y1'}
    }, {
      col1: {value: 'Apple'},
      col2: {value: '20'},
      col3: {value: 'x2'},
      col4: {value: 'y2'}
    }, {
      col1: {value: 'Banana'},
      col2: {value: '15'},
      col3: {value: 'x3'},
      col4: {value: 'y3'}
    }];

    $scope.select = function(row) {
      row.selected=!row.selected;
      // Do something with row.col3.value and row.col4.value
    }
  });

笨蛋: http://plnkr.co/edit/DdO1zBXxkyXWSLA6Gv2x?p=preview

关于javascript - Angularjs 在 ng-repeat 中显示和隐藏按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23393428/

相关文章:

javascript - 为什么 $compile 不评估 ngRepeat 创建的指令中的范围

javascript - 如何在angular js和html5中显示来自javascript对象的特定代码的名称

javascript - 重定向页面后如何保存 HTML 文件

javascript - Angular : ng-src Fallback

javascript - 如何在 Angularjs 中重构闭包中的重复代码?

javascript - 验证 $index 并设置样式

angularjs - 在 Angular ng-repeat 中每隔 2 个项目创建行 - Ionic Grid

Javascript:使用不规则键循环遍历对象内的所有记录

javascript - React 函数导出在导出后不起作用

javascript - 悬停时使图像从暗变亮