html内で画像埋め込みと日付差

簡単な処理をhtmlで作るメモって案外やってないからやってみた。

もうすぐxx日とか表示させてみる。
URLで画像だけでなく、埋め込み画像もやってみよか。

埋め込み画像はhtmlに入れる時base64でエンコードしたものをimg srcってタグに展開する。

base64って7ビット表現やったかな。
元のjpgとかpdfよりもサイズが膨らんでまう。

pdfとかもインライン表示できるし、djangoの処理で日常的にやってるんやけど、一回書いたら問題出たときしか見いひんからここでメモ。

base64変換やってくれるサイトあるんかなって探したらすぐあった。
作者さんありがとう。

画像Base64エンコード - 画像をBase64文字列へ変換 | Web ToolBox
画像ファイルをBase64文字列へ変換することができるツールです。一度に複数の画像をブラウザ上で高速に変換することが可能です!

結論

こうなる。

imgsrc

画像は、左が自分のサイトにある4KBぐらいのjpeg画像で、右がそれをbase64エンコードしてhtmlに埋め込んだもの。
下の方に今日の日付との日数差が出てる。

書いた内容

こんな感じ。

<!doctype html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <title>gvis sample</title>
</head>
<body>
  <div class="header"><font size="8"><center>期限までもうすぐ!!(左がURL指定、右が埋め込み)</center></font></div>
  <br>
  <div class="main" style="text-align: center">
    <img src="https://gavann-it.com/wp-content/uploads/2021/10/mac-Monterey009.jpg"/>
    <img src="" />
    <br>
    <br>

    <center><font size="6">
      <script>
        //比較する日付オブジェクトを2つ用意する
        const today = new Date();
        const year = today.getFullYear();
        const month = today.getMonth() + 1 ;
        const date = today.getDate();

        var dayToday = `${year}/${month}/${date}`;
        document.write("---今日は",dayToday,"なので4月1日まで、");

        var day1 = new Date(dayToday);
        var day2 = new Date("2024/4/1");

        //差日を求める(86,400,000ミリ秒=1日)
        var termDay = (day2 - day1) / 86400000;

        document.write("あと",termDay,"日---");

      </script>
    </font></center>
  </div>
</body>
</html>

javascriptで日付計算けっこう面倒やねんな。

タイトルとURLをコピーしました