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

美加

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

我真正想要的是显示第一个按钮(在第一次显示列表时隐藏第二个按钮),并且在用户单击第一个按钮以选择特定行之后,我想隐藏第一个按钮并显示第二个按钮。2按钮具有不同的ID,文本,样式。因此,对于用户而言,就像在选择之后更改按钮的外观一样。

我尝试在控制器的函数设置showfarebut1/ showfarebut2scope变量populateFareOption(row.col3.value, row.col4.value),但是单击第一个按钮后,所有行都有第二个按钮。

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

的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>

控制者

    $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共享所有行,这导致单击一个按钮影响所有行。您应该使用绑定到当前行的内容: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

屏幕截图

在此处输入图片说明

柱塞: 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

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

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

来自分类Dev

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

来自分类Dev

显示和隐藏ng-repeat列表中的按钮

来自分类Dev

如何使用ng-repeat和ng-if在AngularJS中显示或隐藏某些HTML标签

来自分类Dev

使用 'dirPagination' (AngularJS) 在 ng-repeat 中显示和隐藏 <div>

来自分类Dev

Angularjs 验证和突出显示 ng-repeat 中的输入

来自分类Dev

如何根据对象中的值显示/隐藏ng-repeat中的元素?AngularJS

来自分类Dev

如何根据对象中的值显示/隐藏ng-repeat中的元素?AngularJS

来自分类Dev

AngularJS-基于ng-repeat中的项目数显示/隐藏

来自分类Dev

AngularJS-基于ng-repeat中的项目数显示/隐藏

来自分类Dev

AngularJS:ng-repeat中的动态ng-model名称和显示输入字段之和

来自分类Dev

单击显示/ ng隐藏以显示ng-repeat创建的按钮的列表

来自分类Dev

显示和隐藏ng-repeat循环的元素

来自分类Dev

AngularJS表单通过单选按钮和ng-repeat验证

来自分类Dev

带有ng-repeat的angularjs和动态按钮栏

来自分类Dev

使用自定义指令,ng-show和$ scope在Angularjs中隐藏/显示元素

来自分类Dev

使用自定义指令,ng-show和$ scope在Angularjs中隐藏/显示元素

来自分类Dev

如何使用AngularJS和ng-repeat derective在模态引导中显示图像?

来自分类Dev

ng-repeat中的按钮

来自分类Dev

AngularJS根据ng-repeat中的条件设置按钮文本

来自分类Dev

未选中嵌套ng-repeat中的Angularjs单选按钮

来自分类Dev

AngularJS根据ng-repeat中的条件设置按钮文本

来自分类Dev

ng-if在ng-repeat angularjs中

来自分类Dev

如何在Angularjs中的ng-repeat中显示单行

来自分类Dev

如何在ng-repeat angularjs中显示高位图

来自分类Dev

在ng-repeat Angularjs中显示从日期开始的时间

来自分类Dev

Angularjs ng-repeat必须仅在单个<li>中显示

来自分类Dev

AngularJs-数据未显示在ng -repeat中

来自分类Dev

AngularJS ng-repeat Onclick部分中的显示消息

Related 相关文章

  1. 1

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

  2. 2

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

  3. 3

    显示和隐藏ng-repeat列表中的按钮

  4. 4

    如何使用ng-repeat和ng-if在AngularJS中显示或隐藏某些HTML标签

  5. 5

    使用 'dirPagination' (AngularJS) 在 ng-repeat 中显示和隐藏 <div>

  6. 6

    Angularjs 验证和突出显示 ng-repeat 中的输入

  7. 7

    如何根据对象中的值显示/隐藏ng-repeat中的元素?AngularJS

  8. 8

    如何根据对象中的值显示/隐藏ng-repeat中的元素?AngularJS

  9. 9

    AngularJS-基于ng-repeat中的项目数显示/隐藏

  10. 10

    AngularJS-基于ng-repeat中的项目数显示/隐藏

  11. 11

    AngularJS:ng-repeat中的动态ng-model名称和显示输入字段之和

  12. 12

    单击显示/ ng隐藏以显示ng-repeat创建的按钮的列表

  13. 13

    显示和隐藏ng-repeat循环的元素

  14. 14

    AngularJS表单通过单选按钮和ng-repeat验证

  15. 15

    带有ng-repeat的angularjs和动态按钮栏

  16. 16

    使用自定义指令,ng-show和$ scope在Angularjs中隐藏/显示元素

  17. 17

    使用自定义指令,ng-show和$ scope在Angularjs中隐藏/显示元素

  18. 18

    如何使用AngularJS和ng-repeat derective在模态引导中显示图像?

  19. 19

    ng-repeat中的按钮

  20. 20

    AngularJS根据ng-repeat中的条件设置按钮文本

  21. 21

    未选中嵌套ng-repeat中的Angularjs单选按钮

  22. 22

    AngularJS根据ng-repeat中的条件设置按钮文本

  23. 23

    ng-if在ng-repeat angularjs中

  24. 24

    如何在Angularjs中的ng-repeat中显示单行

  25. 25

    如何在ng-repeat angularjs中显示高位图

  26. 26

    在ng-repeat Angularjs中显示从日期开始的时间

  27. 27

    Angularjs ng-repeat必须仅在单个<li>中显示

  28. 28

    AngularJs-数据未显示在ng -repeat中

  29. 29

    AngularJS ng-repeat Onclick部分中的显示消息

热门标签

归档