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

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

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

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

JavaScript

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

Q&A

解決済

2回答

1305閲覧

getElementsByClassNameかquerySelectorAllを使い日付の要素を取得したいです!

yunyun_jp

総合スコア1

Ruby on Rails

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

JavaScript

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

0グッド

0クリップ

投稿2021/04/18 02:02

編集2021/04/21 10:01

解決したいこと

RailsでWebアプリをつくっています。
購入日と賞味期限をDB上に登録し、その2つのデータの差分で残り日数を表示させたいです
追記
getElementByIdメソッドでは最初の要素しか取得されず、getElementsByClassNameメソッドを使いましたが、今度は取得自体ができなくなってしまいました。コンソールで見るとinnerHTMLが使えないみたいです。
HTMLcollectionというものでdiv要素は取得できていますが、使えるメソッドが少ないみたいで、日付が取得できるか不明です。

発生している問題・エラー

イメージ説明

該当するソースコード

javascript

1window.addEventListener('load', () => { 2 const purchaseInput = document.getElementsByClassName("purchase-date"); 3 const expirationInput = document.getElementsByClassName("expiration-date"); 4 const purchaseDate = new Date(purchaseInput.innerHTML); 5 const expirationDate = new Date(expirationInput.innerHTML); 6 const daysLeft = document.getElementsByClassName("days-left"); 7 daysLeft.innerHTML = (Math.floor( (expirationDate.getTime() - purchaseDate.getTime()) / ( 1000 * 60 * 60 * 24 ))); 8});

ruby

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

ruby

1class ItemsController < ApplicationController 2 before_action :authenticate_user! 3 before_action :set_item, only: [:show, :edit, :update, :destroy] 4 before_action :move_to_index, only: [:edit, :update, :destroy] 5 6 def index 7 @items = Item.where(user_id: current_user.id).order("created_at DESC") 8 end 9 10 def new 11 @item = Item.new 12 end 13 14 def create 15 @item = Item.create(item_params) 16 if @item.save 17 redirect_to root_path 18 else 19 render :new 20 end 21 end 22 23 def show 24 end 25 26 def edit 27 end 28 29 def update 30 if @item.update(item_params) 31 redirect_to item_path(@item) 32 else 33 render :edit 34 end 35 end 36 37 def destroy 38 if @item.destroy 39 redirect_to root_path 40 else 41 redirect_to root_path 42 end 43 end 44 45 private 46 def item_params 47 params.require(:item).permit(:name, :quantity, :purchase_date, :expiration_date, :memo, :image).merge(user_id: current_user.id) 48 end 49 50 def set_item 51 @item = Item.find(params[:id]) 52 end 53 54 def move_to_index 55 unless current_user == @item.user 56 redirect_to root_path 57 end 58 end 59end

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

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

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

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

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

yunyun_jp

2021/04/18 02:43

スタックオーバーフローの方は削除しました。
guest

回答2

0

.getDate -> .getDate()

【Date.prototype.getDate() - JavaScript | MDN】
https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Date/getDate

投稿2021/04/18 04:56

kei344

総合スコア69606

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

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

yunyun_jp

2021/04/18 05:14

コメントありがとうございます! ()つけたのですが まだNaNままです まだ不十分な点があるのでしょうか? ``` window.addEventListener('load', () => { const purchaseDate = document.getElementById("purchase-date"); const expirationDate = document.getElementById("expiration_date"); const pur = new Date(purchaseDate); const exp = new Date(expirationDate); const daysLeft = document.getElementById("days-left"); daysLeft.innerHTML = (Math.floor( exp.getDate() - pur.getDate() )); }); ```
kei344

2021/04/18 05:16

const pur = new Date(purchaseDate.value); (※ HTMLがINPUT要素であった場合)
yunyun_jp

2021/04/18 05:23

大変丁寧なご回答ありがとうございます やはりNaNのままです _item.html.erb追加致しました
guest

0

自己解決

一応この方法で2つの日付の差分は解決できましたが、ただカウントダウンしていない仕様なので、現在の日付と連動して0日まで1日ずつ減っていく実装は別で考えます。

window.addEventListener('load', () => { const arrjsonInput = document.getElementById("arr_json"); for (let i = 0; i < arrjsonInput.value ; i++) { const purchaseInput = document.getElementById("purchase-date"+i); const expirationInput = document.getElementById("expiration-date"+i); const purchaseDate = new Date(purchaseInput.innerHTML); const expirationDate = new Date(expirationInput.innerHTML); const daysLeft = document.getElementById("days-left"+i); daysLeft.innerHTML = (Math.floor( (expirationDate.getTime() - purchaseDate.getTime()) / ( 1000 * 60 * 60 * 24 ))); } });
<main class="main"> <div class="inner"> <div class="card__wrapper"> <input id="arr_json" type="hidden" value="<%= @items.length %>" class='arr_json'/> <% @items.each_with_index do |item, i| %> <div class="content"> <div class="image-content"> <%= link_to image_tag(item.image.variant(resize: '200x200'), class: :card__img ), item_path(item) %> </div> <div class="sub-content"> <span>購入日</span> <div id="purchase-date<%=i %>"> <%= item.purchase_date %></div> </div> <div class="sub-content"> <span>賞味期限</span> <div id="expiration-date<%=i %>"><%= item.expiration_date %></div> </div> <div class="daysleft-content"> <span>残り<span id="days-left<%=i %>"></span>日</span> </div> <div class="nickname-content"> <%= link_to "by #{item.user.nickname}", root_path, class: :card__user %> </div> </div> <% end %> </div> </div> </main>

投稿2021/04/21 10:08

yunyun_jp

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問