2021年12月6日 星期一

退休倒數計時器

最近幾年辦公室將有大量老同事退休, 讓我也意識到退休似乎也離我越來越近了, 沒想到漫長的職場生涯已經走了很大段, 離 2031 年 12 月 31 日 (更正, 是 6 月 30 日) 65 歲屆齡退休已進入 10 年倒數階段. 為了提醒自己老之將至, 用 jQueryUI 寫了一個退休倒數計時器放在我的 GitHub 首頁, 測試網頁如下 : 


<!DOCTYPE html>
<html>
  <head>
    <title>退休倒數計時器</title>
    <meta charset="utf-8">
    <meta http-equiv="cache-control" content="no-cache">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
    <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
    <link href="https://code.jquery.com/ui/1.12.1/themes/hot-sneaks/jquery-ui.css" rel="stylesheet">
    <style>
      body {font-family: Arial, Helvetica, sans-serif;}
      .ui-widget {font-size:80%;}
    </style>
  </head>
  <style>
  </style>
  <body>
    <div class="ui-state-highlight ui-corner-all" style="padding: 5px; margin: 5px;  width:40%;">
      <span class="ui-icon ui-icon-info"></span>
      <span id="msg" style="font-weight: bold;"></span>
    </div>
    <script> 
      $(function(){
        var t=Date.parse('Dec 31, 2031') - new Date().getTime();   //距離目標之毫秒數
        var total_days=Math.floor(t / (1000 * 60 * 60 * 24));  //毫秒轉成天數
        var years=Math.floor(total_days / 365);   //天數轉成年
        var days=total_days % 365;   //用餘數求不足 1 年之日數
        var msg="離 2031 年 12 月 31 日退休還有 " + years + " 年 " + days + " 天";
        $("#msg").text(msg);   //設定凸顯元件之內文
        });
    </script>
  </body>
</html>

此網頁中的 Javascrript 程式使用 Date.parse() 與 Date.getTime() 取得目標日期與現在時間差毫秒數 t, 然後除以 86400000 得到與目標日期之總天數 total_days, 除以 365 得到年數 years (不考慮閏年), 用 % 計算餘數得到日數, 最後將這些資訊用 jQuery 物件的 text() 方法設定到 Highlight 元件的 span 元素裡. 關於 jQueryUI 的 Highlight (高亮度凸顯) 元件, 用法參考: 


我將上面的測試網頁轉貼到我的 GitHub 網站結果如下 :





嗯, 效果不錯, 這樣每次開啟個人網站就會看到提醒了 (日期可能因閏年差 1~2 天). 但如果中樂透, 就馬上退休 (連 200 元從沒中過的狂想), 哈哈.  好久沒寫網頁, 連 jQuery 都快忘記了! 人腦還真是用進廢退. 

2021-12-06 補充 :

下午詢問同事, 我正確退休日期應該是 2031-06-30 才對, 所以又修改上面的 Javascript 程式, 把日期改為 Jun, 30, 結果我離退休已不滿十年了 : 




9 年 207 天也會像過去十年一樣不知不覺就流失, 慎勿放逸啊!  

沒有留言 :