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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

3回答

514閲覧

今月からの前後数ヶ月を取得してページャーとして表示したい

takesu

総合スコア14

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2018/02/20 01:40

編集2018/02/20 01:53

html

1 <ul class="month-pager"> 2 <li> 3 <a href="">9月</a> 4 </li> 5 <li> 6 <a href="">10月</a> 7 </li> 8 <li> 9 <a href="">11月</a> 10 </li> 11 <li> 12 <a href="">12月</a> 13 </li> 14 <li> 15 <a href="">1月</a> 16 </li> 17 <li> 18 <a href="" class="month-pager-current">2月</a> 19 </li> 20 <li> 21 <a href="">3月</a> 22 </li> 23 <li> 24 <a href="">4月</a> 25 </li> 26 <li> 27 <a href="">5月</a> 28 </li> 29 <li> 30 <a href="">6月</a> 31 </li> 32 <li> 33 <a href="">7月</a> 34 </li> 35 </ul> 36

今が2月だとすると、前後5ヶ月を取得して、セレクトボックスで表示したいのですが、javascriptで実装可能でしょうか。
dateで取得してforで繰り返せばいいかなとおもいましたが、画面に反映させるにはどうすればいいのかわからず・・・

javascript

1<script> 2 //日付 3 $(function(){ 4 var dt = new Date(); 5 dt.setMonth(dt.getMonth() - 5); 6 for (var i = 1; i <= 10; i++){ 7 dt += i; 8} 9 10 }); 11 </script>

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

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

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

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

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

m.ts10806

2018/02/20 01:50

提示のhtmlはセレクトボックスではないようですが・・?
takesu

2018/02/20 01:54

間違えていました。ただのhtmlです^^;修正いたしました。
guest

回答3

0

こんにちは。

日付を扱うのに便利な moment.js を使ってみました。
今月を含む、一年分(12ヶ月)を<option>にします。

html

1<select class="month-selector"> 2</select>

javascript

1$(function(){ 2 3 const NUM_MONTHS = 12; 4 5 for (let i = -NUM_MONTHS/2; i < NUM_MONTHS/2; ++ i ) { 6 const date = moment().add(i, 'months'); 7 const option = $('<option>') 8 .val(date.format("YYYYMM")) 9 .text(date.format("YYYY年 M月")) 10 .attr('selected', i==0 ? 'selected' : undefined); 11 $('.month-selector').append(option); 12 } 13 14});

  
以下、デモです。

https://jsfiddle.net/jun68ykt/xhy9n3cm/28/

投稿2018/02/20 02:17

jun68ykt

総合スコア9058

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

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

takesu

2018/02/20 03:12

ありがとうございます。年などを扱う時はこちらの方が良さそうですね。
jun68ykt

2018/02/20 03:28

そうですね。 ある日付に対して、その日付の1ヶ月先の日付だとか10日前の日付だとか、 そういった、 日時+日時の差分=日時 みたいな演算を自分で書かないで、すでによく使われている便利グッズを使って、 なるべく楽したいですからね。
takesu

2018/02/20 04:34

こちらでも実装してみたのですが、過去を5ヶ月、現在の月、未来を5ヶ月の合計11ヶ月表示にしたく、const NUM_MONTHS = 12; ↓ const NUM_MONTHS = 11; にしましたが、おそらく計算がうまくできていないようで、動きませんでした。どのようにすればいいかもしおわかりでしたら教えていただけますと幸いです!
jun68ykt

2018/02/20 05:53

ご質問のタイトル > 今月からの前後数ヶ月を取得して の「数ヶ月」を、 const N として、以下のように すればよいと思います。 https://jsfiddle.net/jun68ykt/xhy9n3cm/36/ 今月含む、 2×N + 1 ヶ月がリストされます。
takesu

2018/02/20 07:49

const N = 5;にして1ヶ月ずつ処理すればいいのですね。ありがとうございます!できました。
guest

0

ベストアンサー

微調整は必要かもしれませんが、こんな感じではいかがでしょうか。

html

1<ul class="month-pager"></ul>

javascript

1 $(function(){ 2 var dt = new Date(); 3 var thismonth = dt.getMonth()+1;//今月 4 for (var i = 0; i <= 10; i++){ 5 var mdt = dt.setMonth(thismonth -6+i);//5ヶ月前を計算 6 var li=document.createElement('li'); 7 var a=document.createElement('a'); 8 $(a).text((dt.getMonth()+1)+"月"); 9 if((dt.getMonth()+1) == thismonth){//今月をカレントに 10 $(a).addClass("month-pager-current"); 11 } 12 $(li).html(a); 13 $(".month-pager").append(li); 14 15 } 16 });

投稿2018/02/20 02:08

編集2018/02/20 02:39
m.ts10806

総合スコア80850

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

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

m.ts10806

2018/02/20 02:11

前後5ヶ月になってなかったので調整しました。
takesu

2018/02/20 02:21

ありがとうございます!forの10を11にすると前後5ヶ月になりました! こんなすぐにできるなんてみなさん本当にすごいですね!!
m.ts10806

2018/02/20 02:26

あれ? 提示したソースで9月~7月になってるはずですが(編集前のソース見られたかも?) なにはともあれ解決したようで良かったです。 実現方法は沢山あるので要件にあったやり方を見つけてくださいね。
m.ts10806

2018/02/20 02:39 編集

あ、 for (var i = 0; i < 10; i++){ じゃなくて for (var i = 0; i <= 10; i++){ ですね。失礼しました。修正しておきます。
takesu

2018/02/20 02:42

なるほどです。そういうことですね! ありがとうございます。
guest

0

普通にforで回せばいいでしょうけどこんな感じでも

javascript

1$(function(){ 2 var d=new Date(); 3 d.setDate(1); 4 var m=d.getMonth()+1;/*すみませんgetDateと書いていたものを修正しました*/ 5 Array(11).fill(null).forEach(function(x,y){ 6 d.setMonth(m+y-6); 7 console.log((d.getMonth()+1)+"月"); 8 }); 9 10});

投稿2018/02/20 02:03

編集2018/02/20 02:08
yambejp

総合スコア114769

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

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

takesu

2018/02/20 03:12

いつもありがとうございます。こんなやり方もあるんですね。とても勉強になります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問