如何利用moment處理時(shí)間戳并計(jì)算時(shí)間的差值
項(xiàng)目使用nodejs寫服務(wù)端,有個(gè)功能就是統(tǒng)計(jì)代理服務(wù)器流量,然后把統(tǒng)計(jì)的數(shù)據(jù)通過(guò)echarts渲染到頁(yè)面。
當(dāng)然統(tǒng)計(jì)數(shù)據(jù)這里用到了 定時(shí)器,在使用的是
var schedule = require( 'node-schedule');
有興趣的同學(xué)可以在npm上搜一搜關(guān)于js定時(shí)任務(wù)的事,其實(shí)都大同小異,差不多都是運(yùn)用corn表達(dá)式。
以下是我的 定時(shí)從代理服務(wù)器獲取數(shù)據(jù) 并存庫(kù)。
schedule.scheduleJob('*/15 * * * * * ', function () {
console.log('timer !!!!!!!!!!');
var dataObj1 = {};
iplists.forEach(function (ele, index) {
var req = http.request("http://" + ele + ":14567/stat", function (res) {
dataObj1.time = new Date(res.headers.date);
dataObj1.ip = req.getHeader("host").split(":")[0];
res.setEncoding('utf-8');
var tempData = '';
res.on('data', function (chunk) {
tempData += chunk;
var resultObj = JSON.parse(tempData);
dataObj1.flow = resultObj.bw15s;
var flow1 = new flowrank1({
ip: dataObj1.ip,
flow: dataObj1.flow,
time: new Date(dataObj1.time)
});
flow1.save(function (err, flow1) {
if (err) {
console.log(err);
return;
}
});
});
});
req.on("error", function (err) {
console.log(err);
});
req.end()
});
});
現(xiàn)在來(lái)展示 需要根據(jù)前端傳過(guò)來(lái)的 時(shí)間戳 來(lái)篩選出數(shù)據(jù)的代碼,處理時(shí)間我用到了moment這個(gè)類庫(kù),基本包含了時(shí)間所有的處理方法。
總結(jié)以下moment的幾個(gè)常用的函數(shù):
moment().startOf('year'); // set to January 1st, 12:00 am this year
moment().startOf('month'); // set to the first of this month, 12:00 am
moment().startOf('quarter'); // set to the beginning of the current quarter, 1st day of months, 12:00 am
moment().startOf('week'); // set to the first day of this week, 12:00 am
moment().startOf('isoWeek'); // set to the first day of this week according to ISO 8601, 12:00 am
moment().startOf('day'); // set to 12:00 am today
moment().startOf('date'); // set to 12:00 am today
moment().startOf('hour'); // set to now, but with 0 mins, 0 secs, and 0 ms
moment().startOf('minute'); // set to now, but with 0 seconds and 0 milliseconds
moment().startOf('second'); // same as moment().milliseconds(0);
moment().diff(Moment|String|Number|Date|Array);
moment().diff(Moment|String|Number|Date|Array, String);
moment().diff(Moment|String|Number|Date|Array, String, Boolean);
var a = moment([2008, 9]);
var b = moment([2007, 0]);
a.diff(b, 'years'); // 1
a.diff(b, 'years', true); // 1.75
moment().add(Number, String);
moment().add(Duration);
moment().add(Object);var moment = require('moment');
var starttime = moment(moment.unix(parseInt(req.query.starttime)).toDate());
console.log("==============");
console.log(moment(moment.unix(parseInt(req.query.starttime)).toDate()));
var endtime = moment(moment.unix(parseInt(req.query.endtime)).toDate());
console.log(moment(moment.unix(parseInt(req.query.endtime)).toDate()));
console.log(endtime.diff(starttime, 'hour'));
console.log(endtime.diff(starttime, 'months'));
console.log(endtime.diff(starttime, 'months'));
/**
* 查詢小于1天的數(shù)據(jù)
*/
if (endtime.diff(starttime, 'hour') <= 24) {
console.log("flowrank1");
flowrank1.find({
ip: req.query.ip,
time: {
$gt: moment.unix(req.query.starttime).toDate(),
$lte: moment.unix(req.query.endtime).toDate()
}
},
{
_id: 0,
ip: 1,
flow: 1,
time: 1
},
function(err, doc) {
if (err) {
console.log("err!!!!!")
console.log(err);
return res.end(JSON.stringify(retcode.operateDbErr));
}
var result = retcode.res_ok;
result.data = doc;
console.log(doc)
res.end(JSON.stringify(result));
})
} else if (endtime.diff(starttime, 'months') == 0) {
console.log("flowrank2!!!!");
flowrank2.find({
ip: req.query.ip,
time: {
$gt: moment.unix(req.query.starttime).toDate(),
$lte: moment.unix(req.query.endtime).toDate()
}
},
{
_id: 0,
ip: 1,
flow: 1,
time: 1
},
function(err, doc) {
if (err) {
console.log("err!!!!!")
console.log(err);
return res.end(JSON.stringify(retcode.operateDbErr));
}
var result = retcode.res_ok;
result.data = doc;
console.log(doc)
res.end(JSON.stringify(result));
})
} else if (endtime.diff(starttime, 'months') >= 1) {
console.log("in flowrank3");
flowrank3.find({
ip: req.query.ip,
time: {
$gt: moment.unix(req.query.starttime).toDate(),
$lte: moment.unix(req.query.endtime).toDate()
}
},
{
_id: 0,
ip: 1,
flow: 1,
time: 1
},
function(err, doc) {
if (err) {
console.log("err!!!!!")
console.log(err);
return res.end(JSON.stringify(retcode.operateDbErr));
}
var result = retcode.res_ok;
result.data = doc;
console.log(doc)
res.end(JSON.stringify(result));
})
} else {
return res.end(JSON.stringify(retcode.res_err));
}總結(jié)
到此這篇關(guān)于如何利用moment處理時(shí)間戳并計(jì)算時(shí)間差值的文章就介紹到這了,更多相關(guān)moment處理時(shí)間戳?xí)r間差內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
鼠標(biāo)右擊事件代碼(asp.net后臺(tái))
本程序由一個(gè)js文件和aspx文件組成,沒(méi)有后臺(tái)CS代碼。2011-01-01
JavaScript如何把兩個(gè)數(shù)組對(duì)象合并過(guò)程解析
這篇文章主要介紹了JavaScript如何把兩個(gè)數(shù)組對(duì)象合并過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
ES6學(xué)習(xí)筆記之正則表達(dá)式和字符串正則方法分析
這篇文章主要介紹了ES6學(xué)習(xí)筆記之正則表達(dá)式和字符串正則方法,結(jié)合實(shí)例形式對(duì)比分析了ES5與ES6正則操作的常用函數(shù)功能與用法區(qū)別,需要的朋友可以參考下2017-04-04
JS雙向鏈表實(shí)現(xiàn)與使用方法示例(增加一個(gè)previous屬性實(shí)現(xiàn))
這篇文章主要介紹了JS雙向鏈表實(shí)現(xiàn)與使用方法,在之前鏈表的基礎(chǔ)上增加一個(gè)previous屬性實(shí)現(xiàn)的雙向鏈表功能,需要的朋友可以參考下2019-01-01
axios請(qǐng)求設(shè)置responseType為'blob'或'arraybuffer&apo
這篇文章主要給大家介紹了關(guān)于axios請(qǐng)求設(shè)置responseType為'blob'或'arraybuffer'下載時(shí)如何正確處理返回值的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
js構(gòu)建二叉樹(shù)進(jìn)行數(shù)值數(shù)組的去重與優(yōu)化詳解
這篇文章主要給大家介紹了關(guān)于js構(gòu)建二叉樹(shù)進(jìn)行數(shù)值數(shù)組的去重與優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03
Bootstrap 附加導(dǎo)航(Affix)插件實(shí)例詳解
附加導(dǎo)航(Affix)插件允許某個(gè) <div> 固定在頁(yè)面的某個(gè)位置。接下來(lái)通過(guò)本文給大家介紹Bootstrap 附加導(dǎo)航(Affix)插件實(shí)例詳解,感興趣的朋友一起看看吧2016-06-06

