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

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

ただいまの
回答率

90.83%

  • JavaScript

    14802questions

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

  • jQuery

    6155questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

jquery セレクトボックスのプルダウン展開後の初期表示位置を調整したい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 72

freedomman

score 17

 前提・実現したいこと

お世話になります。
セレクトボックスのプルダウン展開後の初期表示位置の調整をjqueryで実行してます。

行っていることは現在の西暦から40をマイナスし、
その年くらいからの初期表示を行っております。

例)2018 - 40 = 1978
プルダウン内の「1978」付近から表示されるようにする

現在は静的にですが、
$("#hoge option[value='1978']").after($("<option>").val("").text("").prop('selected', true)); 
このようなコードでvalueが1978のオプションの後に、選択状態の空要素を追加してむりやり初期表示位置を調整しております。

できれば
$("#hoge option[value='変数の値']").after($("<option>").val("").text("").prop('selected', true));
のようにしたいのですが、可能でしょうか

変数の値は「selectVal」という変数になります。

 発生している問題・エラーメッセージ

$("#hoge option[value='1978']").after($("<option>").val("").text("").prop('selected', true));
の[value='1978']に変数「selectVal」を反映したい

 該当のソースコード

<script>
    (function ($) {
        $(function () {
            var date = new Date(),
                getYear = date.getFullYear(),
                //現在の西暦から40マイナス
                targetAge = getYear - 40;
            console.log(targetAge);
            var selectVal = $("#hoge").val();
            selectVal = targetAge;
            console.log(selectVal);
            targetAge = selectVal;
            $("#hoge option[value='1978']").after($("<option>").val("").text("").prop('selected', true));
        });
    })(jQuery);
</script>

 該当のソースコード

<select id="hoge" name="example">
        <option value="">選択してください</option>

        <option value="1900">1900</option>

        <option value="1901">1901</option>

        <option value="1902">1902</option>

        <option value="1903">1903</option>

        <option value="1904">1904</option>

        <option value="1905">1905</option>

        <option value="1906">1906</option>

        <option value="1907">1907</option>

        <option value="1908">1908</option>

        <option value="1909">1909</option>

        <option value="1910">1910</option>

        <option value="1911">1911</option>

        <option value="1912">1912</option>

        <option value="1913">1913</option>

        <option value="1914">1914</option>

        <option value="1915">1915</option>

        <option value="1916">1916</option>

        <option value="1917">1917</option>

        <option value="1918">1918</option>

        <option value="1919">1919</option>

        <option value="1920">1920</option>

        <option value="1921">1921</option>

        <option value="1922">1922</option>

        <option value="1923">1923</option>

        <option value="1924">1924</option>

        <option value="1925">1925</option>

        <option value="1926">1926</option>

        <option value="1927">1927</option>

        <option value="1928">1928</option>

        <option value="1929">1929</option>

        <option value="1930">1930</option>

        <option value="1931">1931</option>

        <option value="1932">1932</option>

        <option value="1933">1933</option>

        <option value="1934">1934</option>

        <option value="1935">1935</option>

        <option value="1936">1936</option>

        <option value="1937">1937</option>

        <option value="1938">1938</option>

        <option value="1939">1939</option>

        <option value="1940">1940</option>

        <option value="1941">1941</option>

        <option value="1942">1942</option>

        <option value="1943">1943</option>

        <option value="1944">1944</option>

        <option value="1945">1945</option>

        <option value="1946">1946</option>

        <option value="1947">1947</option>

        <option value="1948">1948</option>

        <option value="1949">1949</option>

        <option value="1950">1950</option>

        <option value="1951">1951</option>

        <option value="1952">1952</option>

        <option value="1953">1953</option>

        <option value="1954">1954</option>

        <option value="1955">1955</option>

        <option value="1956">1956</option>

        <option value="1957">1957</option>

        <option value="1958">1958</option>

        <option value="1959">1959</option>

        <option value="1960">1960</option>

        <option value="1961">1961</option>

        <option value="1962">1962</option>

        <option value="1963">1963</option>

        <option value="1964">1964</option>

        <option value="1965">1965</option>

        <option value="1966">1966</option>

        <option value="1967">1967</option>

        <option value="1968">1968</option>

        <option value="1969">1969</option>

        <option value="1970">1970</option>

        <option value="1971">1971</option>

        <option value="1972">1972</option>

        <option value="1973">1973</option>

        <option value="1974">1974</option>

        <option value="1975">1975</option>

        <option value="1976">1976</option>

        <option value="1977">1977</option>

        <option value="1978">1978</option>

        <option value="1979">1979</option>

        <option value="1980">1980</option>

        <option value="1981">1981</option>

        <option value="1982">1982</option>

        <option value="1983">1983</option>

        <option value="1984">1984</option>

        <option value="1985">1985</option>

        <option value="1986">1986</option>

        <option value="1987">1987</option>

        <option value="1988">1988</option>

        <option value="1989">1989</option>

        <option value="1990">1990</option>

        <option value="1991">1991</option>

        <option value="1992">1992</option>

        <option value="1993">1993</option>

        <option value="1994">1994</option>

        <option value="1995">1995</option>

        <option value="1996">1996</option>

        <option value="1997">1997</option>

        <option value="1998">1998</option>

        <option value="1999">1999</option>

        <option value="2000">2000</option>

        <option value="2001">2001</option>

        <option value="2002">2002</option>

        <option value="2003">2003</option>

        <option value="2004">2004</option>

        <option value="2005">2005</option>

        <option value="2006">2006</option>

        <option value="2007">2007</option>

        <option value="2008">2008</option>

        <option value="2009">2009</option>

        <option value="2010">2010</option>

        <option value="2011">2011</option>

        <option value="2012">2012</option>

        <option value="2013">2013</option>

        <option value="2014">2014</option>

        <option value="2015">2015</option>

        <option value="2016">2016</option>

        <option value="2017">2017</option>

        <option value="2018">2018</option>
</select>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

その年くらいからの初期表示を行っております。 

「くらい」の定義がわかりませんが、初期値を「その年」からにしてはいけないのでしょうか?

$(function(){
  var d=new Date();
  $('#hoge').val(d.getFullYear()-40);
});

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/04 14:40

    ありがとうございます。
    説明が抜けていてすみません。
    初期表示は何も選択されていない状態にしておきたいです。

    キャンセル

checkベストアンサー

0

すでにtargetAgeが取得できているので、埋め込むだけでいいのではないでしょうか

$('#hoge option[value="' + targetAge.toString() + '"]').after($('<option selected="selected"></option>'));

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/04 16:25

    やりたい事が解決できました。
    この度はありがとうございました。
    toString()でtargetAgeの変数を文字列で返すということですね。
    consoleで確認したら違いがわかりました。

    キャンセル

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

  • ただいまの回答率 90.83%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • JavaScript

    14802questions

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

  • jQuery

    6155questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。