How I can do update relative time from momentjs
in real time for user?
I have computed:
computed: {
ago() {
return moment().fromNow
I solve this using a global "ticker" in my Vuex store. It starts incrementing itself on load every 30 seconds. Descriptive messages of the time compare to this ticker instead of to other implementations of "now" or whatever. The advantage of this technique over something like every UI element iterating its own datetime ticker every second is that you don't have reactive elements in Vue all refreshing themselves on a regular basis all willy nilly. In my application, the one global "pseudo-now" ticker iterates every 30 seconds and all elements which provide descriptive accounts of the time all refresh at once in one frame. This benefits performance.
snippet from a relevant Vuex store:
import Vue from 'vue'
const TICKER_INTERVAL = 30000; // milliseconds
let tickerPointer = null;
const data = {
state: {
now: new Date,
},
mutations: {
refreshTicker(state) {
state.now = new Date;
},
},
actions: {
startTicker({commit}) {
if (tickerPointer === null) {
tickerPointer = setInterval(() => {
commit('refreshTicker');
}, TICKER_INTERVAL);
}
},
haltTicker({state}) {
clearInterval(tickerPointer);
state.now = null;
tickerPointer = null;
},
"StartTicker" is dispatched once by the top of my application upon load.