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

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

ただいまの
回答率

90.47%

  • Monaca

    995questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

monaca ons-selectにoptionを追加したい

解決済

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 659

a1-1969

score 8

monacaにてons-selectにボタンのクリックでoptionを追加していきたいです。

以下のコードを実行すると、ons-selectの下部に追加され、ons-select内部に
追加されません。

onsen uiのサンプル通りだと思うのですが。

https://ja.onsen.io/v2/api/js/ons-select.html#tutorial

  <div style="padding: 10px 20px 10px 25px;">
    <ons-select id="opt" size="3">
        <option value="111">111</option>
    </ons-select>
  </div>

  <ons-button disabled="true" onclick="btn_clk(event)">追加</ons-button>
//追加
function btn_clk(event) {
  const option = document.createElement('option');
  option.innerText = "333";
  document.getElementById('opt').appendChild(option);
}

ボタンをクリックする度に、333が追加されていくのが、やりたい事です。

よろしくお願いいたします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

ons-select 分の回答を以下に記載します。動作確認をお願いします。

<body>
  <ons-select id="opt">
    <option value="111">111</option>
  </ons-select>

  <ons-button onclick="btn_click()">追加</ons-button>

  <script>
      function btn_click()
      {
        var option = document.createElement('option');
        option.setAttribute("value", "333")
        option.innerHTML = "333";

        document.querySelector(".select-input").appendChild(option);
      }
  </script>
</body>

暗黙的ですが ons-select タグを利用すると内部に <select class="select-input"> というタグが生成されます。console.log() などで id:opt の要素を確認してみると分かりやすいでしょう。

今回の例は画面中に一つしか存在しないため document.querySelector で取得しました。

取得後の処理は JavaScript の前回の回答と、指定方法が変わっただけで、ほぼ同じです。

// Onsen-UI 的に問題を解決したかったのですが参考になる資料が見つかりませんでした。
// より良い回答は有識者に期待したいところ。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/10/12 09:55

    ご回答ありがとうございました。
    ons-selectに追加できました。

    //しかし、Onsen-UIの情報が少ないですね。
    //MONACAの有償ユーザになると、簡単に解決できたのでしょうか。

    ありがとうございました。

    キャンセル

0

ひとつめ、ons-button のパラメータ disabled を削除しましょう。ボタンが利かない理由はそれです。(disabled="false" などとしても駄目)
 

ふたつめ、ボタンクリック時の処理は下記を確認してください。コピペして動かしてみましょう。

<body>
  <select id="opt">
    <option value="111">111</option>
  </select>

  <ons-button onclick="btn_click()">追加</ons-button>

  <script>
      function btn_click(event)
      {
        var option = document.createElement('option');
        option.setAttribute("value", "333")
        option.innerHTML = "333";

        document.getElementById('opt').appendChild(option);
      }
  </script>
</body>

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/10/06 10:12

    ご回答いただきまして、ありがとうございます。
    ひとつめの「disabled」は投稿時の誤記でした。
    失礼いたしました。

    ひたつめですが、単純な「select」の場合は、追加出来るのですが、
    OnsenUIの「ons-select」だと「ons-select」の中に追加できず、
    「ons-select」の下に追加されているような表示になります。

    よろしくお願いいたします。

    キャンセル

  • 2017/10/10 14:34

    あらら、ごめんなさい。 勘違いして select で回答してしまいました。
    ons-select 分の回答を別で投稿します。ご確認ください。

    キャンセル

関連した質問

  • 解決済

    onsenUIの「popover」について

    【質問内容】 「popover」を使用して、数種類あるポップアップ(新着通知、フォルダを作成、編集)から押されたポップアップに応じて処理を変更したいのですが、個別に判定するにはど

  • 解決済

    ons-tabの非表示

    前提・実現したいこと MonacaでOnsenUI v2を使ったアプリを製作していて、ons-tabを用いてページの切り替えを行っているのですが、ons-tab内のページでpus

  • 解決済

    スワイプ操作での画面遷移

    前提・実現したいこと Monacaでアプリ開発の勉強をしているのですが、OnsenUIのpushpageで画面遷移をした後に、画面を上にスワイプすることでpop-pageができる

  • 解決済

    Onsen UIのalert-dialogウィンドウをTextarea内の文字数制限超過時に表示した...

    こんにちは、プログラミング初心者です。 Onsen UIの利用をこちらで皆さんに勧めていただいてから、Onsenについての基本事項を同時進行で勉強しています。 現在、Monaca(

  • 解決済

    指定時刻に画面遷移をする方法が分からない

    前提・実現したいこと MonacaとOnsenUIを用いてアプリ開発を勉強しているのですが、ピッカーなどでユーザーに時間を入力してもらった後に、その時刻になったら画面遷移をする。と

  • 解決済

    Onsen UI 2 「pushPage」の引数の受け取り方

    Onsen UI 1.xのときは、pushPageメソッドの第2引数でパラメータを渡し、 getCurrentPageメソッドで受け取ることができていたと思います。 Onsen

  • 受付中

    OnsenUIで複数ページを使用するときの戻るボタンが実装できない

    こんにちは。 Monacaのアプリ製作プラットフォームを使っています。 使用しているJSフレームワークは、OnsenUI V2 JS Minimumです。 OnsenUIで複数ペー

  • 解決済

    ons-checkboxの状態取得について

    monaca上にonsenUIを用いてアプリを開発中です。 以下のHTMLでAppleとBananaどちらが選択されているかを取得するJSはどのように記述すればよいのでしょうか?

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

  • Monaca

    995questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。