简体   繁体   English

当过滤表为空时显示自定义消息

[英]Show custom message when filtered table is empty

I have a table that is populated via JSON. 我有一个通过JSON填充的表。

This table has a input box as a filter. 该表具有一个输入框作为过滤器。 My question is how do I display a custom message if the search doesn't return any results? 我的问题是,如果搜索未返回任何结果,如何显示自定义消息?

This is my filter javascript: 这是我的过滤器javascript:

(function(document) {
'use strict';

var LightTableFilter = (function(Arr) {

    var _input;

    function _onInputEvent(e) {
        _input = e.target;
        var tables = document.getElementsByClassName(_input.getAttribute('data-table'));
        var columns = (_input.getAttribute('data-table-columns') || '').split(',');
        Arr.forEach.call(tables, function (table) {
            Arr.forEach.call(table.tBodies, function (tbody) {
                Arr.forEach.call(tbody.rows, function (row) {
                    _filter(row, columns);
                });
            });
        });
    }

function _filter(row, columns) {
    var text, val = _input.value.toLowerCase();
    if (columns.length) {
        columns.forEach(function (index) {
            text += ' ' + row.cells[index].textContent.toLowerCase();
        });
    } else {
    text = row.textContent.toLowerCase();
}
row.style.display = text.indexOf(val) === -1 ? 'none' : 'table-row';
}

    return {
        init: function() {
            var inputs = document.getElementsByClassName('light-table-filter');
            Arr.forEach.call(inputs, function(input) {
                input.oninput = _onInputEvent;
            });
        }
    };
})(Array.prototype);

document.addEventListener('readystatechange', function() {
    if (document.readyState === 'complete') {
        LightTableFilter.init();
    }
});



})(document);

I added data-err to indicate the id of a span to display upon no results. 我添加了data-err来指示跨度的ID,如果没有结果将显示该ID。 The span gets added in init() Also fixed bug with filter where it wasn't applying for u,n,d,e,f,i (letters in 'undefined'). 跨度被添加到init()中,还修复了没有使用u,n,d,e,f,i(未定义字母)的过滤器错误。

  (function(document) { 'use strict'; var LightTableFilter = (function(Arr) { var _input; function _onInputEvent(e) { _input = e.target; var tables = document.getElementsByClassName(_input.getAttribute('data-table')); var columns = (_input.getAttribute('data-table-columns') || '').split(','); Arr.forEach.call(tables, function(table) { Arr.forEach.call(table.tBodies, function(tbody) { var rows = tbody.rows.length; var errSpan = document.getElementById(_input.getAttribute('data-err')); Arr.forEach.call(tbody.rows, function(row) { rows -= _filter(row, columns); }); errSpan.style.display = rows > 0 ? 'none' : 'inline-block'; }); }); } function _filter(row, columns) { var text = '' /* fix bug with 'undefined' */, val = _input.value.toLowerCase(); var filtered = 0; if (columns.length) { columns.forEach(function(index) { text += ' ' + row.cells[index].textContent.toLowerCase(); }); console.log(text); } else { text = row.textContent.toLowerCase(); } var display = 'table-row'; if (text.indexOf(val) === -1) { display = 'none'; filtered = 1; } row.style.display = display; return filtered; } return { init: function() { var inputs = document.getElementsByClassName('light-table-filter'); Arr.forEach.call(inputs, function(input) { var errSpanId = input.getAttribute('data-err'); var errSpan = document.createElement('span'); errSpan.id = errSpanId; errSpan.style.display = 'none'; errSpan.textContent = 'No results to display'; document.body.appendChild(errSpan); /* Should append somewhere more appropriate */ input.oninput = _onInputEvent; }); } }; })(Array.prototype); document.addEventListener('readystatechange', function() { if (document.readyState === 'complete') { LightTableFilter.init(); } }); })(document); 
 <input type='text' class='light-table-filter' data-table='example' data-table-columns='0' data-err='err-example' /> <table class='example'> <thead> <tr> <th>Column</th> </tr> </thead> <tbody> <tr> <td>One</td> </tr> <tr> <td>Two</td> </tr> <tr> <td>Three</td> </tr> </tbody> </table> 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM