欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS獲取日期的方法實例【昨天,今天,明天,前n天,后n天的日期】

 更新時間:2023年05月13日 08:16:15   作者:索隆  
這篇文章主要介紹了JS獲取日期的方法,結合具體實例分析了javascript計算昨天,今天,明天,前n天,后n天日期及對應的星期幾實現技巧,需要的朋友可以參考下

本文實例講述了JS獲取日期的方法。分享給大家供大家參考,具體如下:

原理很簡單,一天的時間的毫秒數是1000*60*60*24,

前n天的日期就是現在日期換成毫秒-n*1000*60*60*24。

再把這個值換成日期即可(通過setTime方法)

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
 <title>www.dbjr.com.cn 日期計算</title>
 <meta name="Generator" content="EditPlus">
 <meta name="Author" content="">
 <meta name="Keywords" content="">
 <meta name="Description" content="">
 </head>
 <body>
 <select id="num" name="num" style="width:150px" onchange="ff()">
        <option value="-1">昨天</option>
        <option value="0">今天</option>
        <option value="1">明天</option>
 </select><br>
 <textarea id="ar" rows="3" cols="20">
 haha
</textarea>
<br/>
<input type="text" value="" name="bday" id="bday"/>天之前
<input type="button" onclick="bday()" value="計算"><br/>
<input type="text" value="" name="aday" id="aday"/>天之后
<input type="button" onclick="aday()" value="計算"><br/>
 </body>
 <script>
 ff();
function ff(){
 var obj=document.getElementById("num");
 var v1=obj.options[obj.selectedIndex].text;
 var v2=obj.options[obj.selectedIndex].value;
 var tvv=giveDateStr(getTargetday(v2));
 document.getElementById('ar').innerText=tvv;
}
function isInteger(obj) {
 var r = /^\+?[1-9][0-9]*$/;  //正整數 
 return r.test(obj); 
}
function bday(){
 var bef=document.getElementById("bday").value;
 if(isInteger(bef)){
   var bvv=giveDateStr(getTargetday(-bef));
   document.getElementById('ar').innerText=bvv;
 }else{
   alert("請輸入正整數!");
   document.getElementById("bday").value='';
   document.getElementById("bday").focus();
 }
 
}
function aday(){
 var atf=document.getElementById("aday").value;
 if(isInteger(atf)){
   var avv=giveDateStr(getTargetday(atf));
   document.getElementById('ar').innerText=avv;
 }else{
   alert("請輸入正整數!");
   document.getElementById("aday").value='';
   document.getElementById("aday").focus();
 }
}
function getTargetday(num){
  var number=null;
  if(num==null||num==0){
   number=0;
  }else{
    number=num;
  }
  var  today=new  Date();
  var  targetday_milliseconds=today.getTime()+1000*60*60*24*number;
  var  targetday=new  Date();
  targetday.setTime(targetday_milliseconds); //注意,這行是關鍵代碼
  return targetday;
}
function giveDateStr(dd){
  var riqiyue=dd.getMonth()+1;
  var riqihao=dd.getDate();
  var riqixingqi=null;
  if(dd.getDay()=='0'){
   xingqi="星期日";
  }else if(dd.getDay()=='1'){
   xingqi='星期一';
  }else if(dd.getDay()=='2'){
   xingqi='星期二';
  }else if(dd.getDay()=='3'){
   xingqi='星期三';
  }else if(dd.getDay()=='4'){
   xingqi='星期四';
  }else if(dd.getDay()=='5'){
   xingqi='星期五';
  }else if(dd.getDay()=='6'){
   xingqi='星期六';
  }
  var riqi=riqiyue+"月"+riqihao+"日"+"("+xingqi+")";
  return riqi;
}
</script>
</html>

運行效果如下:

js 日期 獲取今天、昨天、明天第一個函數

  function getDay(day){
    var today = new Date()
    // 獲取時間戳(毫秒級)
    /*
      day為1,則是,明天的時間戳
      day為-1,則是,昨天的時間戳
      day為-2,則是,前天的時間戳
    */
    var targetday_milliseconds = today.getTime() + 1000 * 60 * 60 * 24 * day
    // Date.setTime(時間戳):設置當前日期的時間
    today.setTime(targetday_milliseconds)
    console.log('today=', today) // today= Sun Mar 05 2023 16:14:56 GMT+0800 (中國標準時間)
    var tYear = today.getFullYear() // 年
    var tMonth = today.getMonth() // 月
    var tDate = today.getDate() // 日
    tMonth = this.doHandleMonth(tMonth + 1)
    tDate = this.doHandleMonth(tDate)
    console.log('返回年月日=', tYear + '-' + tMonth + '-' + tDate)
    return tYear + '-' + tMonth + '-' + tDate
  }
  function doHandleMonth(month) {
    var m = month
    if (month.toString().length == 1) {
      m = '0' + month
    }
    return m
  }

js獲取今天昨天明天的日期第二個函數

/* 
  * @params date 日期
  * @params type 日期 prev/current/next 昨天/今天/明天
  * @params fmt 日期拼接符
*/
function getDays(date, type, fmt) {
    let currentDate = new Date(date)
    let y = currentDate.getFullYear()
    let m = currentDate.getMonth() + 1
    let d = currentDate.getDate()
    function dateFormat(date, fmt) {
        let y = new Date(date).getFullYear()
        let m = new Date(date).getMonth() + 1
        let d = new Date(date).getDate()
        return `${y}${fmt}${m}${fmt}$vvxyksv9kd`
    }
    switch (type) {
        case "prev":
            if (d - 1 < 1) {
                if (m - 1 < 1) {
                    y = y - 1
                    m = 12
                } else {
                    m = m - 1
                }
                d = new Date(y, m, 0).getDate()
            } else {
                d = d - 1
            }
            break
        case "current":
            break
        case "next":
            if (d + 1 > new Date(y, m, 0).getDate()) {
                if (m + 1 > 12) {
                    y = y + 1
                    m = 1
                    d = 1
                } else {
                    m = m + 1
                    d = 1
                }
            } else {
                d = d + 1
            }
            break;
    default:
      break;
    }
    return dateFormat(new Date(`${y}-${m}-$vvxyksv9kd`), fmt)
}
console.log(getDays(new Date('2021-1-1'), "prev", "-"));

PS:這里再為大家推薦幾款比較實用的天數計算在線工具供大家使用:

在線日期/天數計算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi

在線日期計算器/相差天數計算器:
http://tools.jb51.net/jisuanqi/datecalc

在線日期天數差計算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq

在線天數計算器:
http://tools.jb51.net/jisuanqi/datejsq

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript時間與日期操作技巧總結》、《JavaScript+HTML5特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • js使用formData實現批量上傳

    js使用formData實現批量上傳

    這篇文章主要為大家詳細介紹了js使用formData實現批量上傳,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • 微信小程序實現自動回復圖片消息

    微信小程序實現自動回復圖片消息

    這篇文章主要介紹了微信小程序實現客服消息自動回復圖片消息,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-01-01
  • JavaScript之Getters和Setters 平臺支持等詳細介紹

    JavaScript之Getters和Setters 平臺支持等詳細介紹

    現在,JavaScript的Getters和Setters使用非常廣泛,它和每個JavaScript開發(fā)者的切身利益息息相關,我們先來快速了解什么是Getters和Setters,以及它們?yōu)槭裁春苡杏?然后,我們來看看現在都有哪些平臺支持Gettets和Setters
    2012-12-12
  • javascript中的緩動效果實現程序

    javascript中的緩動效果實現程序

    javascript中的緩動效果可以應用于很多地方,比如距離位移上的變化:圖片的滾動、焦點圖的輪轉切換,透明度上的變化:漸隱漸現。凡是存在運動的狀態(tài)都適用,下面以最基本的塊在容器內從左到右滑動為例,講下幾種不同的緩動處理方式
    2012-12-12
  • jsPDF生成pdf后在網頁展示實例

    jsPDF生成pdf后在網頁展示實例

    本文為大家介紹下jsPDF生成pdf后如何在網頁展示,下面有個不錯示例,大家可以參考下
    2014-01-01
  • 關于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法

    關于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法

    下面小編就為大家?guī)硪黄P于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 用js實現計算代碼行數的簡單方法附代碼

    用js實現計算代碼行數的簡單方法附代碼

    用js實現計算代碼行數的簡單方法附代碼...
    2007-08-08
  • 原生js實現類似彈窗抖動效果

    原生js實現類似彈窗抖動效果

    這篇文章主要介紹了原生js實現類似彈窗抖動效果的相關資料,推薦給大家,需要的朋友可以參考下
    2015-04-04
  • JS實現彈出浮動窗口(支持鼠標拖動和關閉)實例詳解

    JS實現彈出浮動窗口(支持鼠標拖動和關閉)實例詳解

    這篇文章主要介紹了JS實現彈出浮動窗口,可支持鼠標拖動和關閉的功能,界面美觀大方,涉及javascript動態(tài)創(chuàng)建對話框的相關技巧,需要的朋友可以參考下
    2015-08-08
  • js內存泄漏場景、如何監(jiān)控及分析詳解

    js內存泄漏場景、如何監(jiān)控及分析詳解

    js內存泄漏的含義就是當已經不需要某塊內存時這塊內存還存在著,垃圾回收機制就是間歇的不定期的尋找到不再使用的變量,并釋放掉它們所指向的內存,這篇文章主要給大家介紹了關于js內存泄漏場景、如何監(jiān)控及分析的相關資料,需要的朋友可以參考下
    2021-11-11

最新評論