質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

1160閲覧

現在の日付と連動して賞味期限の残り日数を1日ずつ減らしいく表示をしたい!

yunyun_jp

総合スコア1

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/04/21 10:11

解決したいこと

プログラミング初学者です。Ruby on Railsで賞味期限の残り日数を現在の日付に連動する1日ずつ減っていく表示にさせるアプリを作りたいです。
1日経つと残り●日が1日ずつ減るイメージです。時間までは表示せず日付だけを考えてます。現在、残り日数は購入日と賞味期限の差分です。
賞味期限から現在の日付の差分を1ずつ減らすイメージでしょうか?
railsでの一からの作り直しも検討してます。
イメージ説明

該当するソースコード

javascript

1window.addEventListener('load', () => { 2 const arrjsonInput = document.getElementById("arr_json"); 3 for (let i = 0; i < arrjsonInput.value ; i++) { 4 const purchaseInput = document.getElementById("purchase-date"+i); 5 const expirationInput = document.getElementById("expiration-date"+i); 6 const purchaseDate = new Date(purchaseInput.innerHTML); 7 const expirationDate = new Date(expirationInput.innerHTML); 8 const daysLeft = document.getElementById("days-left"+i); 9 daysLeft.innerHTML = (Math.floor( (expirationDate.getTime() - purchaseDate.getTime()) / ( 1000 * 60 * 60 * 24 ))); 10 } 11});

ruby

1<main class="main"> 2 <div class="inner"> 3 <div class="card__wrapper"> 4 <input id="arr_json" type="hidden" value="<%= @items.length %>" class='arr_json'/> 5 <% @items.each_with_index do |item, i| %> 6 <div class="content"> 7 <div class="image-content"> 8 <%= link_to image_tag(item.image.variant(resize: '200x200'), class: :card__img ), item_path(item) %> 9 </div> 10 <div class="sub-content"> 11 <span>購入日</span> 12 <div id="purchase-date<%=i %>"> <%= item.purchase_date %></div> 13 14 </div> 15 <div class="sub-content"> 16 <span>賞味期限</span> 17 <div id="expiration-date<%=i %>"><%= item.expiration_date %></div> 18 </div> 19 <div class="daysleft-content"> 20 <span>残り<span id="days-left<%=i %>"></span></span> 21 </div> 22 <div class="nickname-content"> 23 <%= link_to "by #{item.user.nickname}", root_path, class: :card__user %> 24 </div> 25 </div> 26 <% end %> 27 </div> 28 </div> 29</main>

自分で試したこと

どのような解決法があるか検討もつきません。
railsだとdowntoとDateクラスを組み合わせるのでしょうか?
なにかヒントになるような事があれば宜しくおねがいします!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

etsuhisa

2021/04/21 12:14

賞味期限の残り日数を現在の日付に連動するとのことですが、残り日数は購入日に関わらず、賞味期限と現在の日付の差で求まるように思います。現在の日付が進めば残り日数も減ります(ページを読み込みなおせば)。違う場合、残り日数の期待する結果を教えていただけますか?
yunyun_jp

2021/04/21 13:48

ありがとうございます。おっしゃるとおりですね。 const today = new Date(); に変えたらうまくいったのですが、 日数が1日ずれてしまいます。 コンソールで内容みてみます ありがとうございました!
guest

回答1

0

ベストアンサー

残り日数は購入日と賞味期限の期日差分ではなく、賞味期限と今日の日付の差分ではないのですか?

なので賞味期限の日付から今日の日付を引いた日数を表示すれば良いと思います。

Dateクラスは減算が可能だったと思います。

投稿2021/04/21 18:39

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yunyun_jp

2021/04/22 00:41

回答ありがとうございました 比較するのは現在と賞味期限ですね 根本的な間違いをしていました。 ありがとうございます!勉強になります
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問