javascript - 如何在也有现有点击绑定(bind)的表头上切换 css 类?

标签 javascript jquery knockout.js knockout-2.0

我正在尝试在表头切换CSS类。但是,表头已经有一个点击绑定(bind):我引用了 docs here :

默认情况下,我需要在表头上有一个类(thead),然后在单击表头时添加/删除(切换)该类。目标是使用该类向可排序的表头添加视觉描述:

下面是进行排序的代码: 注意: 此代码和想法复制自 Ryan Rahlf blogArticle here :

我认为可以从排序函数调用 css 绑定(bind),以便在单击列头时应用或删除它:

    self.sort = function(header, event){

        // This is the existing click binding (sort)
        // Place css logic in here so that individual thead class is toggled when clicked.

        if(self.activeSort === header) {

            header.asc = !header.asc;

        } else {
            self.activeSort = header;
        }

        var prop = self.activeSort.sortPropertyName;
        var ascSort = function(a,b){ return a[prop] < b[prop] ? -1 : a[prop] > b[prop] ? 1 : a[prop] == b[prop] ? 0 : 0; };
        var descSort = function(a,b){ return a[prop] > b[prop] ? -1 : a[prop] < b[prop] ? 1 : a[prop] == b[prop] ? 0 : 0; };
        var sortFunc = self.activeSort.asc ? ascSort : descSort;
        self.Artist.sort(sortFunc);
    };

Example on JSfiddle :

最佳答案

有很多方法可以做到这一点,但为了不改变您在此处所做的许多事情,请参阅其中一种方法的片段:

function viewModel() {

        var self = this;
        
        self.orderedBy = ko.observableArray([]);
        
        self.Artist = ko.observableArray([
            {
                'LastName': 'Simon',
                'FirstName': 'Paul'
            }
            ,
            {
                'LastName': 'McCartney',
                'FirstName': 'Paul'
            },
            {
                'LastName': 'McKnight',
                'FirstName': 'Brian'
            },
            {
                'LastName': 'Morrison',
                'FirstName': 'Marc'
            }]);

        self.headers = [
            {title: 'First Name', sortPropertyName: 'FirstName', asc: true},
            {title: 'Last Name', sortPropertyName:  'LastName', asc:true}
        ];

        self.sort = function(header, event){          
          
          self.activeSort = header;  
          
          if(self.orderedBy.indexOf(header.title)>=0)
            self.orderedBy.remove(header.title);          
          else
            self.orderedBy.push(header.title);
          
          self.activeSort.asc = !self.activeSort.asc;
          var prop = self.activeSort.sortPropertyName;
          var ascSort = function(a,b){ return a[prop] < b[prop] ? -1 : a[prop] > b[prop] ? 1 : a[prop] == b[prop] ? 0 : 0; };
          var descSort = function(a,b){ return a[prop] > b[prop] ? -1 : a[prop] < b[prop] ? 1 : a[prop] == b[prop] ? 0 : 0; };
          var sortFunc = self.activeSort.asc ? ascSort : descSort;
          self.Artist.sort(sortFunc);
        };
    }

    ko.applyBindings(viewModel());
.ordered{
  background-color: yellow;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
    <table>
        <thead>
        <tr data-bind="foreach: headers">
            <th data-bind="click: sort, text: title, css:{ordered: orderedBy.indexOf(title)>=0}"></th>
        </tr>
        </thead>

        <tbody data-bind="foreach: Artist">
        <tr>
            <td data-bind="text: FirstName"></td>
            <td data-bind="text: LastName"></td>
        </tr>
        </tbody>
    </table>

希望有用。

关于javascript - 如何在也有现有点击绑定(bind)的表头上切换 css 类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34259418/

相关文章:

jquery - 使用 jQuery 阻止 onClick 触发两次

javascript - 事件按键在 Mozilla 中不起作用 - knockout

javascript - KnockoutJS 数组

javascript - 如何使用knockoutjs在点击函数中传递固定参数?

javascript - 如何处理 svg 中的 <path> 笔划宽度变为零

javascript - ng-select 下拉 ajax/对象映射

jquery - 如何制作带有播放和暂停按钮的自动幻灯片放映?

javascript - 创建自定义 URL 以触发按钮

javascript - 将 Javascript UUID 函数翻译成 C

jquery - 如何平均数字并动态显示结果