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

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

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

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

Q&A

解決済

3回答

1166閲覧

JavaScript: getElementById().Value;について

rails_ruby

総合スコア87

JavaScript

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

0グッド

0クリップ

投稿2019/02/07 05:06

編集2019/02/07 05:24

やりたいこと

**document.getElementById('off_date').value;**でHTMLのvalueを引っ張ってきています。
off_dateのvalueには複数のデータがあり、そのデータをすべて取得したい。
for文で回せばデータを取り出せるのかなとは思いつつそのやり方が分からなくて困っています。
もしお分かりの方いましたらご教授していただけると幸いです。

ruby

1<% @off_date.each do |off_date_hidden| %> 2<input type="hidden" name="off_date" value="<%= off_date_hidden.off_days_date.strftime("%Y-%m-%dT") %>", id='off_date' readonly> 3<% end %> 4<% @off_start.each do |off_start_hidden| %> 5<input type="hidden" name="off_start" value="<%= off_start_hidden.off_days_start_time.strftime("%H:%M") %>", id='off_start' readonly> 6<% end %> 7<% @off_finish.each do |off_finish_hidden| %> 8<input type="hidden" name="off_finish" value="<%= off_finish_hidden.off_days_finish_time.strftime("%H:%M") %>", id='off_finish' readonly> 9<% end %>

js

1var abc = document.getElementById('off_date').value; 2var bcd = document.getElementById('off_start').value; 3var cde = document.getElementById('off_finish').value; 4console.log(abc + bcd + '~' + cde);//19年02月06日08:00~20:00,19年02月07日010:00~15:00,19年02月09日010:00~18:00 5//3つデータがあるはずですがconsoleでみると1つしか表示されません。 6 7const BUSY = [ 8 abc + bcd, 9 '2019-02-09T11:30' 10]; 11console.log(BUSY);

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

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

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

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

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

x_x

2019/02/07 05:22

提示コードがHTMLではないのでサーバー側言語(Ruby?)のタグをつけてください。
rails_ruby

2019/02/07 05:25 編集

すいませんでした。今修正しました。 それともしお分かりでしたらご教示頂けると幸いです。
guest

回答3

0

提示の記述ですとeach doでループしてるのでidが重複します
https://reference.hyper-text.org/html5/attribute/id/

任意のクラスで取得してはいかがでしょうか

投稿2019/02/07 05:16

編集2019/02/07 05:17
SakuBlade

総合スコア375

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

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

0

ベストアンサー

id重複はできないので.getElementsByName()なり.querySelectorAll()なりで取得します。

JavaScript

1var abc = Array.from(document.getElementsByName('off_date'), x => x.value); 2console.log(abc); // ["2019-02-06T", "2019-02-07T", "2019-02-09T"]

投稿2019/02/07 05:40

x_x

総合スコア13749

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

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

0

前回のつづきですね

javascript

1<script> 2const BUSY = [ 3 '2019-02-12T10:00', 4 '2019-02-12T10:30', 5 '2019-02-13T10:00', 6 '2019-02-02T10:00', 7 '2019-02-02T10:30', 8 '2019-02-03T10:00', 9 '2019-02-03T10:30', 10 '2019-02-09T10:00', 11 '2019-02-09T10:30', 12 '2019-02-09T23:30' 13]; 14window.addEventListener('DOMContentLoaded', function(){ 15 document.querySelector('#btn').addEventListener('click',function(){ 16 var offset=30; 17 [].forEach.call(document.querySelectorAll('.dates'),function(x,y){ 18 var d0=x.value; 19 var t1=document.querySelectorAll('.time_start')[y].value; 20 var t2=document.querySelectorAll('.time_finish')[y].value; 21 var d1=new Date(d0+" "+t1);d1.setTime(d1.getTime()+1000*60*60*9); 22 var d2=new Date(d0+" "+t2);d2.setTime(d2.getTime()+1000*60*60*9); 23 var m=Array((d2.getTime()-d1.getTime())/1000/60/offset+1).fill(null).map(function(x,y){ 24 return (new Date(d1.getTime()+1000*60*offset*y)).toISOString().substr(0,16); 25 }); 26 [].push.apply(BUSY,m); 27 }); 28 console.log(BUSY); 29 }); 30}); 31</script> 32<input type="date" value="2019-01-01" class="dates"><br> 33<input type="time" value="10:00" class="time_start"><br> 34<input type="time" value="19:00" class="time_finish"><br> 35<hr> 36<input type="date" value="2019-01-02" class="dates"><br> 37<input type="time" value="11:00" class="time_start"><br> 38<input type="time" value="14:00" class="time_finish"><br> 39<hr> 40<input type="date" value="2019-01-03" class="dates"><br> 41<input type="time" value="01:00" class="time_start"><br> 42<input type="time" value="23:00" class="time_finish"><br> 43<hr> 44<input type="button" value="go" id="btn"> 45

投稿2019/02/07 05:44

yambejp

総合スコア114757

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問