亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中根據(jù)時間戳判斷對應的時間(今天 昨天 前天)

 更新時間:2019年12月20日 13:27:21   作者:ShiyuTim  
這篇文章主要介紹了vue中 根據(jù)時間戳 判斷對應的時間(今天 昨天 前天),需要的朋友可以參考下

根據(jù)時間戳 來顯示對應的時間段

本文是根據(jù)vue縮寫,但是原理都是想通的

根據(jù)一個時間戳,然后來顯示對應的時間段。如果為今天,則顯示對應的time,如果為昨天,則顯示為昨天,如果為前天,則顯示為前天。剩下的顯示為對應的日期

需求定義好了,然后開始實現(xiàn):

首先,是把時間戳轉換為對應的時間格式,js提供了原生的獲取對應年、月、日等格式的方法,但是不夠靈活,這里提供了一個網上找的比較靈活獲取固定格式的函數(shù)。

const formatDate = (date, fmt) => {
 date = new Date(date);
 if (typeof (fmt) === "undefined") {
  fmt = "yyyy-MM-dd HH:mm:ss";
 }
 if (/(y+)/.test(fmt)) {
  fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length))
 }
 let o = {
  'Y': date.getFullYear(),
  'M+': date.getMonth() + 1,
  'd+': date.getDate(),
  'H+': date.getHours(),
  'm+': date.getMinutes(),
  's+': date.getSeconds()
 }
 for (let k in o) {
  if (new RegExp(`(${k})`).test(fmt)) {
   let str = o[k] + ''
   fmt = fmt.replace(RegExp.$1, RegExp.$1.length === 1 ? str : ('00' + str).substr(str.length));
  }
 }
 return fmt
}

使用這個函數(shù),需要提供一個時間戳和一個日期格式。

// `+new Date()` 為獲取當前時間戳的簡寫形式 
// `yyyy-MM-dd HH:mm:ss`為想要獲取的日期格式
formatDate(+new Date(), 'yyyy-MM-dd HH:mm:ss') // 2019-12-18 20:29:31

接下來是使用過濾器來對時間戳進行過濾。vue提供了過濾器,可以定義全局過濾器和本地過濾器,我們定義一個本地過濾器

// common.js
// 這里使用模塊化,把過濾器函數(shù)定義在外部js文件內
const formatDate ......

export { formatDate }

// index.vue
import { formatDate } from 'common'

export default {
 data () {
 return {
  time: 1576673222857
 }
 },
 methods: {},
 created() {},
 filters: {
 formateDate(data, fmt) {
  return formatDate(data, fmt)
 }
 }
}

定義好了過濾器,就可以在頁面中使用了

// index.vue

<template>
 <div>
 <span>{{ time | formateDate('MM-dd') }}</span>
 </div>
</template>

使用|(管道符)來對時間戳進行過濾,管道符左側為過濾器的第一個參數(shù),第二個參數(shù)為過濾的格式。定義好之后就會根據(jù)格式顯示對應的時間格式了。

接下來最后一步就是對比今天的日期,來顯示對應的時間(昨天,前天)
這里使用vue的if else來判斷應該顯示哪種日期格式。

<template>
 <div>
 <span v-if="new Date(time).getDate() === new Date().getDate()">{{ time | formateDate('HH:mm') }}</span> 
 // 這里把時間戳轉換為`日`,然后跟當前的`日`進行比較,如果相等,則說明是今天的時間戳,則顯示`time`
 <span v-else-if="new Date(time).getDate() === (new Date().getDate() - 1)">{{ time | formateDate('HH:mm') }}</span> 
  // 這里把**當前**的時間戳 `-1`,說明是昨天。比如說今天是18日,`-1`之后就是17,如果`time`轉換后 與 17 相等,說明應該顯示為`昨天`。
  <span v-else-if="new Date(time).getDate() === (new Date().getDate() - 2)">{{ time | formateDate('HH:mm') }}</span> 
  // `-2`為`前天`
  <span v-else>{{ time | formateDate('MM-dd') }</span>
  // 否則顯示為對應的日期
 </div> 
</template>

好了,以上是根據(jù)日期去比較來顯示對應的時間?!?但是,你以為完了嗎?

有一個重要的問題就是,每個月都有30日中的其中一日,今天是12月18日,比較18相等,顯示對應的時間,但是如果為11月18日呢?如果還顯示對應的時間顯然是不對了。

所以應該把年、月、日 全都對比一下,然后在確定對應的時間。

所以代碼應該如下:

 <span class="lastDate"
  v-if="(new Date(time).getDate() == new Date().getDate()) && (new Date(item.lastTime).getMonth() == new Date().getMonth()) && (new Date(item.lastTime).getYear() == new Date().getYear())"
   >{{time | FormatDate( 'HH:mm')}}</span>
   
 <span class="lastDate"
  v-if="(new Date(time).getDate() == new Date().getDate() - 1) && (new Date(item.lastTime).getMonth() == new Date().getMonth()) && (new Date(item.lastTime).getYear() == new Date().getYear())"
   >昨天</span>

 <span class="lastDate"
  v-if="(new Date(time).getDate() == new Date().getDate() - 1) && (new Date(item.lastTime).getMonth() == new Date().getMonth()) && (new Date(item.lastTime).getYear() == new Date().getYear())"
   >前天</span>
   
 <span v-else>{{ time | formateDate('MM-dd') }</span>

雖然是完成了比較年月日后,來顯示對應的日期。但是看看這些代碼巨丑無比,而且極不容易理解,所以,我們不應該在html里面寫這么多判斷代碼,so,我們來封裝成一個函數(shù),然后在來使用函數(shù)對比。

在封裝函數(shù)之前,我們先確定一下,上面這些判斷代碼中,有哪些相同的地方,哪些不同的地方。

相同的是

  • 使用new Date(time) 來對比new Date()
  • 使用getDate() / getMonth() / getYear()
  • 使用兩個&&來對比

不同的是

  • 一個new Date()里面需要參數(shù)time,一個不要參數(shù)

有些需要-對應的數(shù)字

大概梳理了一下出以上部分,把相同的寫進函數(shù)內,不同的使用形參,也就是arguments。

// common.js

const compareDate = (timestamp, day = 0) => {
 // timestamp 為要傳入的時間戳
 // day 為要減去的日子 因為比較*當天*的話,是不需要減的,所以默認定義成0,
 
 // 根據(jù)上面分析,有些需要參數(shù)`time`,有些不需要,所以使用一個函數(shù)來區(qū)分一下 
 let newDate = (time = null) => {
 return time === null ? new Date() : new Date(time)
 }
 
 // 這里返回 比較后的值,比較成功,則返回`true`,失敗則返回`false`
 return (newDate(timestamp).getDate() == newDate().getDate() - day) && (newDate(timestamp).getMonth() == newDate().getMonth()) && (newDate(timestamp).getYear() == newDate().getYear()) 
}

export {
 compareDate
}

上面就是封裝好的函數(shù),但是有一個問題,就是函數(shù)里面寫死了比較年月日,因為目前都需要比較三個,就先這樣,有時間在改為根據(jù)參數(shù)在來區(qū)分比較年或月或日。

然后就可以使用了,使用的時候需要注意一下,我的這篇博客里面已經說了,這里就不細說, 直接放代碼:

// index.vue
import { compareDate } from 'common.js'
data() {
 return {
 compare: compareDate
 }
}
<template>
 <div>
  <span v-if="compare(time)">{{time | FormatDate( 'HH:mm')}}</span>
  <span v-else-if="compare(time, 1)">昨天</span>
  <span v-else-if="compare(time, 2)">前天</span>
   <span v-else>{{time | FormatDate( 'MM-d')}}</span>
 </div> 
</template>

這樣是不是簡潔了很多呢?,而且也容易理解,看著也清晰。

以上就是根據(jù)時間戳,來比較當前時間顯示對應的日期。如果有更好的方法歡迎討論。如果有疑問也可以留言。

總結

以上所述是小編給大家介紹的vue中根據(jù)時間戳判斷對應的時間(今天 昨天 前天),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • Vue自定義指令的使用實例介紹

    Vue自定義指令的使用實例介紹

    作為使用Vue的開發(fā)者,我們對Vue指令一定不陌生,諸如v-model、v-on、等,同時Vue也為開發(fā)者提供了自定義指令的api,熟練的使用自定義指令可以極大的提高了我們編寫代碼的效率,讓我們可以節(jié)省時間開心的摸魚
    2023-04-04
  • vue.set() (this.$set)的用法及說明

    vue.set() (this.$set)的用法及說明

    這篇文章主要介紹了vue.set() (this.$set)的用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue+echarts實現(xiàn)動態(tài)繪制圖表及異步加載數(shù)據(jù)的方法

    vue+echarts實現(xiàn)動態(tài)繪制圖表及異步加載數(shù)據(jù)的方法

    vue寫的后臺管理,需要將表格數(shù)據(jù)繪制成圖表(折線圖,柱狀圖),圖表數(shù)據(jù)都是通過接口請求回來的。這篇文章主要介紹了vue+echarts 動態(tài)繪制圖表及異步加載數(shù)據(jù)的相關知識,需要的朋友可以參考下
    2018-10-10
  • vue3之聲明式和編程式導航詳解

    vue3之聲明式和編程式導航詳解

    這篇文章主要介紹了vue3之聲明式和編程式導航,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 記一次Vue.js混入mixin的使用(分權限管理頁面)

    記一次Vue.js混入mixin的使用(分權限管理頁面)

    這篇文章主要介紹了記一次Vue.js混入mixin的使用(分權限管理頁面),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 解決vue3+vite配置unplugin-vue-component找不到Vant組件

    解決vue3+vite配置unplugin-vue-component找不到Vant組件

    這篇文章主要為大家介紹了vue3+vite配置unplugin-vue-component找不到Vant組件問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • VUE中使用Vue-resource完成交互

    VUE中使用Vue-resource完成交互

    本篇文章主要介紹了VUE中使用Vue-resource完成交互,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 網站國際化多語言處理工具i18n安裝使用方法圖文詳解

    網站國際化多語言處理工具i18n安裝使用方法圖文詳解

    國際化是設計軟件應用的過程中應用被使用與不同語言和地區(qū),下面這篇文章主要給大家介紹了關于網站國際化多語言處理工具i18n安裝使用方法的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • 在vue中使用防抖函數(shù)組件操作

    在vue中使用防抖函數(shù)組件操作

    這篇文章主要介紹了在vue中使用防抖函數(shù)組件操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue 開發(fā)一個按鈕組件的示例代碼

    vue 開發(fā)一個按鈕組件的示例代碼

    本篇文章主要介紹了vue 開發(fā)一個按鈕組件的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03

最新評論