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

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

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

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

jQuery

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

Q&A

解決済

2回答

3013閲覧

jQueryを使ってhtmlのデータリストの値を全て取得したい。

pepe1122

総合スコア14

JavaScript

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

jQuery

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

0グッド

0クリップ

投稿2020/06/16 06:50

コンボボックスのオプションの項目を全て取得し比較したいとおもっております

jqをつかってコンボボックス(datalist)の値を全て取得し、
テキストボックスの値と比較したいのですが。

セレクトボックスと同じ様に値を取得しようとしたのですが上手く取得することができず困っております。

option項目は動的に作っているので新しいlist作って比較しております。

jq書き慣れておらず初心者で変何個と書いているかと思いますがご教授ください。
よろしくおねがしまします。

該当のソースコード

html

1<script> 2 function myfunc() { 3 var list = []; 4 var times = $('#data').children(); 5 console.log(times); 6 7 for (var i=0; i<times.length; i++) { 8 list.push($(this).text()); 9 } 10 console.log(list); 11 var newdata = $("#data").val(); 12 13 for (var i=0; i<list.length; i++) { 14 if (list === newdata){ 15 console.log("同じ"); 16 }else{ 17 console.log("ない"); 18 } 19 } 20 21 } 22</script> 23 24<input type="text" class="combo" id="data" list="datalist" onchange="myfunc()"> 25 26 <datalist id="datalist"> 27 <option value="1">1000</option> 28 <option value="2">1100</option> 29 <option value="3">1200</option> 30 <option value="4">1300</option> 31 <option value="5">1400</option> 32 </datalist>

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

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

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

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

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

guest

回答2

0

ベストアンサー

コンボボックスのオプションの項目を全て取得

こういうことですか?

js

1 var times = $('#datalist').children(); 2 3 for (var i=0; i<times.length; i++) { 4 list.push($(times[i]).text()); 5 }

投稿2020/06/16 07:02

Lhankor_Mhy

総合スコア36960

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

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

pepe1122

2020/06/16 07:12

ありがとうございました凡ミスしておりました。
guest

0

こんな感じでしょうか?

javascript

1<script> 2$(function(){ 3 $('#data').on('change',function(){ 4 var val=$(this).val(); 5 var list=$("#"+$(this).attr('list')).find('option').map(function(){ 6 return $(this).val(); 7 }).get(); 8 var match=list.map(function(x){ 9 return x==val?"同じ":"ない"; 10 }); 11 console.log(list); 12 console.log(match); 13 }); 14}); 15</script> 16 17<input type="text" class="combo" id="data" list="datalist"> 18<datalist id="datalist"> 19<option value="1">1000</option> 20<option value="2">1100</option> 21<option value="3">1200</option> 22<option value="4">1300</option> 23<option value="5">1400</option> 24</datalist>

投稿2020/06/16 07:31

yambejp

総合スコア116724

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問