Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/388.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 仅在第12天之前过滤Moment.js_Javascript_Datatables_Momentjs - Fatal编程技术网

Javascript 仅在第12天之前过滤Moment.js

Javascript 仅在第12天之前过滤Moment.js,javascript,datatables,momentjs,Javascript,Datatables,Momentjs,我有一个数据表,并使用矩过滤日期。我的问题是,如果我在第12天之前输入天,工作正常,但在第12天之后没有过滤我的数据。例如,2021年1月1日至2021年12月1日之间的日期工作正常,但如果我输入2021年1月1日和2021年1月13日,则不会获得任何数据 // Extend dataTables search $.fn.dataTable.ext.search.push( function (settings, data, dataIndex) {

我有一个数据表,并使用矩过滤日期。我的问题是,如果我在第12天之前输入天,工作正常,但在第12天之后没有过滤我的数据。例如,2021年1月1日至2021年12月1日之间的日期工作正常,但如果我输入2021年1月1日和2021年1月13日,则不会获得任何数据

// Extend dataTables search
        $.fn.dataTable.ext.search.push(
            function (settings, data, dataIndex) {
                var min = $('#min-date').val();
                var max = $('#max-date').val();
                var createdAt = data[0] || 0; // Our date column in the table
                moment().format('DD/MM/YYYY');

                if (
                    (min == "" || max == "")
                    ||
                    (moment(createdAt, 'DD/MM/YYYY').isSameOrAfter(min, 'DD/MM/YYYY') && moment(createdAt, 'DD/MM/YYYY').isSameOrBefore(max, 'DD/MM/YYYY'))
                ) {
                    return true;
                }
                return false;
            }
        );

 function dtConvFromJSON(data) {
            if (data == null) return '1/1/1950';
            var r = /\/Date\(([0-9]+)\)\//gi
            var matches = data.match(r);
            if (matches == null) return '1/1/1950';
            var result = matches.toString().substring(6, 19);
            var epochMilliseconds = result.replace(
                /^\/Date\(([0-9]+)([+-][0-9]{4})?\)\/$/,
                '$1');
            var b = new Date(parseInt(epochMilliseconds));
            var c = new Date(b.toString());
            var curr_date = c.getDate();
            var curr_month = c.getMonth() + 1;
            var curr_year = c.getFullYear();
            var curr_h = c.getHours();
            var curr_m = c.getMinutes();
            var curr_s = c.getSeconds();
            var curr_offset = c.getTimezoneOffset() / 60
            var d = curr_date.toString() + '/' + curr_month.toString() + '/' + curr_year.toString();
            return d;
        }
Iam在此使用dtConvFromJson函数

  "columns": [
                { "data": "Date", render: function (data, type, full) { return dtConvFromJSON(data); }, "autoWidth": true },
我解决了这个问题

我已将函数dtConvFromJSON(数据)函数更改为

 function dtConvFromJSON(data) {
  return new Date(parseInt(data.replace('/Date(', '')))
}

瞧!现在工作

您能否回答这个问题以说明如何以及在何处使用
dtConvFromJSON(data)
函数?另外,您将什么
数据
传递到该函数中?(一个猜测:“第13天”是不是被当作一年中某个月份的数字来处理,而不是作为一个月中某一天的数字来处理?)我编辑了这个问题。我认为“第13天”作为一年中的一个月来处理,您将什么
数据
传递到该函数中?你能给我们看一些源JSON数据吗?日期:“/Date(1609016400000)/”谢谢你的更新。我使用一行数据,使用以下JSON进行测试:
[{“Date”:/Date(1609016400000)/“}]
,并使用两个
字段。过滤按预期工作。我无法重现你的问题。您可能需要提供一个。