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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

12664閲覧

セレクトボックスで、選択する年を現在の年までにしたい。

destrudo

総合スコア143

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/05/29 01:46

<form method="get" action=""> <select name="years"> <option value="">--</option> <option value="2015">2015</option> <option value="2016">2016</option> <option value="2017">2017</option> <option value="2018">2018</option> <option value="2019">2019</option> <option value="2020">2020</option> </select> <input type="submit"/> </form>

セレクトボックスで選択する年を現在までの年にしたいです。例えば今は2017年なので、2017年までしか表示されない、来年になったら2018年まで表示するような仕様にしたいです。何かいい方法はないでしょうか。

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

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

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

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

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

guest

回答3

0

ベストアンサー

泥臭いやり方ですが

PHPであれば、

PHP

1$year = date('Y');

で現在の年を取得することができます。

あとはfor文を利用して、年が20XX年から今年までの繰り返しで

<option value=""></option> にforのインデックスを埋め込んでいけばよいと思います。

投稿2017/05/29 01:50

s.t.

総合スコア2021

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

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

0

回答を元にfor文で実装できました。

<?php $year=date('Y') ;?> <SELECT name="years"> <option value="">--</option> <?php for($i=2014; $i<=$year; $i++){ echo '<option value="'.$i.'">'.$i.'</option>'; } ?> </SELECT>

投稿2017/05/29 02:28

destrudo

総合スコア143

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

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

0

サーバーサイドの言語が使えない環境であればこうですかね。

HTML

1<select name="years" id="years"> 2<option value="" selected>--</option> 3</select> 4 5<script> 6var term_years = 5; //何年分表示するか 7var now = new Date(); //Dateで現在の日付情報を取得 8var thisyear = now.getFullYear(); // 今年 9$(document).ready( function(){ 10 //開始を設定値、終了を今年としてループし、optionを追加 11 for(i=(thisyear-term_years);i<=thisyear;i++){ 12 option = $('<option>') 13 .val(i) 14 .text(i); 15 16 $("#years").append(option); 17 } 18}); 19 20</script>

※jQuery使用してます

念のため何をしているかコメントを書きましたが、それぞれの関数や機能の意味は調べてみてください。

投稿2017/05/29 02:03

編集2017/05/29 02:08
m.ts10806

総合スコア80850

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問