如何解决Moment.js 仅在第 12 天之前过滤
我有一个数据表并使用时刻来过滤日期。我的问题是,如果我在第 12 天之前输入几天工作正常但在第 12 天之后没有过滤我的数据。例如,01/01/2021 和 12/01/2021 之间的日期工作正常,但如果我输入 01/01/2021 和 13/01/2021 没有得到任何数据。
// 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;
}
"columns": [
{ "data": "Date",render: function (data,type,full) { return dtConvFromJSON(data); },"autoWidth": true },
解决方法
我解决了问题。
我已将函数 dtConvFromJSON(data) 函数更改为
function dtConvFromJSON(data) {
return new Date(parseInt(data.replace('/Date(','')))
}
瞧!现在工作!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。