【问题标题】:Conditional ng-class on icon in table cell表格单元格中图标上的条件 ng-class
【发布时间】:2016-07-06 18:37:41
【问题描述】:

我有一个表格并使用 ng-repeat 将我的单元格与数据绑定。一个单元格具有编辑、保存、删除图标。如果已发布订单,则应禁用删除/保存图标,并且图标也应为不同颜色。我能够禁用删除/保存图标的单击事件,但无法弄清楚如何更改 css 类。使用此代码无法单击保存和删除。我想把它们变成浅灰色或一些明显不同的颜色。

这是 HTML:

       <tbody>
             <tr ng-repeat="order in vm.orders track by $index"  ng-dblclick="vm.editOrder(order)" style="cursor:pointer" ng-class="{'class':order.invoiceStatus, 'disabled-order': !order.invoiceStatus}">                                            
               <td ng-bind="(order.dtInvoiced | date:'MM/dd/yyyy' )"> </td>                                                
               <td ng-bind="order.invoiceNumber"></td>
               <td ng-bind="order.invoiceItems.mdbsPoNumber"></td>
               <td align="center" ng-bind="order.lines"></td>
               <td ng-bind="(order.total | number:2)"></td>
               <td align="center" ng-bind="order.carrier"></td>                                                
               <td>
                 <a ng-click="vm.editOrder(order)"><i class="fa fa-pencil fa-2x"></i></a>
                 <a ng-click="order.disabledToggle || vm.saveOrder(order)"><i class="fa fa-check fa-2x"></i></a>
                 <a ng-click="order.disabledToggle || vm.removeOrder(order)"><i class="fa fa-trash fa-2x link-icon"></i></a>
                </td>
              </tr>
         </tbody>

这里是禁用保存和删除图标点击事件的JS:

   function orderItems() {
    var orders;
    if (vm.Criteria != null) {
            orderService.getOrderData(vm.Criteria)
    .then(function (result) {
        vm.data = result.data;
        orders = vm.data;
        for (var i = 0; i < vm.data.length; i++) {
            orders[i].disabledToggle = false;
            if (orders[i].invoiceStatus == "RCV") {
                orders[i].disabledToggle = true;                    
            }
            else {
                orders[i].disabledToggle = false;
            }
            vm.orders.push(orders[i]);                
        }

    });
    }
}

图标里我也试过了:

<i ng-class="order.invoiceStatus = order.disabledToggle ? 'disabled-order class' : 'class' "></i>

【问题讨论】:

  • 我在使用ng-class时总是参考这篇文章:scotch.io/tutorials/the-many-ways-to-use-ngclass希望对你有帮助!
  • @mhodges我看到那篇文章掩盖了它,但在底部找到了我的答案,谢谢
  • 太棒了!不客气,很高兴它有帮助

标签: javascript css angularjs


【解决方案1】:

您可以使用 ng-class 来评估变量是否为真。如果变量为真,那么类选择器将被注入到元素中:

<a ng-click="order.disabledToggle || vm.saveOrder(order)"><i ng-class="{ 'cssCheckDisabled': jsCheckDisabled } class="fa fa-check fa-2x"></i></a>

在这种情况下,我们正在评估 jsCheckDisabled。一旦尝试,cssCheckDisabled 类选择器就会被注入到元素中。

然后就像在你的 CSS 中创建一个类选择器来做你想做的一样简单:

cssCheckDisabled {
 color: red;
}

【讨论】:

  • 哎呀,请阅读问题中的 cmets...任何方式都会在此处留下答案。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-06-22
  • 2011-07-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多