
こんにちは、
初心者で色々なサイトを参考に作成しているのですが、どれもうまくいかず、助けて下さい。
phpとjavascriptをを用いて
csvを読み込みし、csvから連動したプルダウンを作りたいです。
例えば、csv からプルダウンにて
都道府県を選択し
その都道府県の中から市町村を選択すると
何曜日が来場可能かが選択できるようにしたいのです。
test.csv
1,東京都,江戸川区,月曜日
1,東京都,江戸川区,火曜日
1,東京都,練馬区,水曜日
1,東京都,練馬区,木曜日
2,埼玉県,川口市,金曜日
2,埼玉県,川口市,土曜日
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
こんにちは
検索すれば、いろいろ見つかると思いますし、「セレクトの連動」はさほど特殊な例ではないので、ライブラリ化したものもいろいろあるようです。
(少し旧い例ですが)
https://mars-2.hatenadiary.org/entries/2007/11/09
https://nodoame.net/archives/4593
phpからhtmlを出力しているのなら、データを直接スクリプト内に書き出しても良いですし、別ファイルにする場合は、js形式にしておけばscriptタグでそのまま読み込むことが可能です。
テキストファイルのままの場合は、HttpRequestで読み込むことも可能ではあります。
条件が不明なので、以下に、スクリプトから読み込む簡単な例を。
・テキストデータの1項目目の意味が不明ですが、とりあえずそのまま。
・データは、ご提示の形式(カンマ区切りクォーテーションなし)で、
htmlと同じフォルダにあると仮定。
・データチェックは行っていません。整合のとれたデータが前提です。
・同期読込みにしてしまいましたが、「非推奨」になったようなので、
非同期に書き換えた方が宜しいかも知れません。
以下ご参考までに。
<!DOCTYPE HTML>
<html lang="ja">
<head><title>Sample</title>
<style>
#hoge select{ width: 8em; margin-right: 2em; }
</style>
</head>
<body>
<form id="hoge">
<select name="select1"></select>
<select name="select2"></select>
<select name="select3"></select>
</form>
<script>
const req = new XMLHttpRequest();
req.open('GET', './test.csv', false);
req.send();
const data = req.responseText.replaceAll('\r','').
split('\n').map(d => d.split(',')).filter(d => d.length>1);
const S = {
elms: [...document.querySelectorAll('#hoge select')],
clear: m => { S.elms[m].innerHTML = "" },
choose: m => {
const c = {}, sVal = S.elms.map( e => e.value );
data.forEach( d => {
let f = true;
for( let i = 1; i <= m; i++) if(d[i] != sVal[i - 1]) f = false;
if(f) c[d[m+1]] = 1;
});
return c;
},
set: m => {
S.clear(m);
for( const k in S.choose(m)){
const opt = `<option value="${k}">${k}</option>`;
S.elms[m].insertAdjacentHTML('beforeend', opt);
}
if(m+1 < S.elms.length) S.set(m+1);
}
};
S.set(0);
document.getElementById('hoge').addEventListener('change', e => {
const m = S.elms.indexOf(e.target);
if(m>-1 && m+1 < S.elms.length) S.set(m + 1);
});
</script>
</body>
</html>
ありがとうございます。
セレクト連動はいただいたURLは存じておりました。
すでにできてはいたのですが、
PHPやjavascriptの知識がない方がcsvで編集してきたものを
いただくので、いちいち変更するのが面倒で、直接できないものかと
考えていました。
上記で動かしてみましたが、うまくいかず、いろいろ試してみます。
ありがとうございました。
No.1
- 回答日時:
範囲名を付けた場所に読み込むようにすれば良いだけだと思うんだけど...。
あと、プルダウンというよりも、フィルタ処理のほうが適切な気がする。
オートフィルタを設定すれば良いんじゃないかな。
先頭行で表示する値を選択するだけです。
複数選択できるので、場合によっては
「東京」「江戸川区または中野区または新宿区」
なんて使い方で絞り込みもできる。
ありがとうございます。
今後増えたり減ったりするので、フィルターだと知識がある人じゃないとなおせないかなと考え、csvからできないかなと考えていたところです。
もう少しがんばってみます
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 転職 長く続けられる好条件の求人でしょうか? 3 2023/07/12 18:45
- 政治 参議院の一票の格差を解消し、なおかつ問題の多い隣の県との合区を解消する方法を考えました 2 2022/11/15 11:40
- その他(国内) 3時!夜中なのか早朝なのか微妙な時間、5時に出るならシャワー浴びてお茶淹れて神棚、仏壇 2 2022/05/20 03:58
- 公園・庭園 台場公園 2 2022/12/02 18:45
- その他(国内) 1番2番3番…と争う? 2 2022/12/06 19:52
- Excel(エクセル) 【Excel】住所に郵便番号を付記する方法 3 2022/05/07 17:15
- MySQL 下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 神奈川県の市区町村の一覧。ただ 3 2023/05/01 18:01
- その他(社会科学) 埼玉県民を差別する人について 経験上、埼玉県を差別的に見る人っていわゆる三大都市圏ではないところ出身 5 2022/09/11 10:11
- その他(国内) 良く、東京と大坂や名古屋、何処が一番、都会ですか?みたいな質問が有りますけど、あれって「区」まで入れ 3 2022/03/27 17:52
- 卓球 東京都、神奈川、埼玉で、日曜日に卓球で団体で借りれる体育館を探しています。何か、おすすめのところはな 1 2023/07/31 21:19
このQ&Aを見た人はこんなQ&Aも見ています
-
それもChatGPT!?と驚いた使用方法を教えてください
仕事やプライベートでも利用が浸透してきたChatGPTですが、こんなときに使うの!!?とびっくりしたり、これは画期的な有効活用だ!とうなった事例があれば教えてください!
-
歳とったな〜〜と思ったことは?
歳とったな〜〜〜、老いたな〜〜と思った具体的な瞬間はありますか?
-
コンビニでおにぎりを買うときのスタメンはどの具?
コンビニでおにぎりを買うとき、何の具材を選ぶことが多いですか?
-
人生でいちばんスベッた瞬間
誰しも、笑いをとろうとして失敗した経験があると思います。
-
「これいらなくない?」という慣習、教えてください
現代になって省略されてきたとはいえ、必要性のない慣習や風習、ありませんか?
-
プルダウンメニューを別ファイルで管理するには?
JavaScript
-
プルダウンメニューでCSVデータを出力する方法
PHP
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Selectボックスの幅を自動で広...
-
プルダウン 項目が多いので先頭...
-
CSVファイルを読みこみ、プルダ...
-
JQuery selectが反映されない
-
document.form で nullまたは...
-
selectメニューのselectedの位...
-
jQuery セレクトボックスで選択...
-
連動セレクトメニュー option...
-
selectタグに直接onChangeを書...
-
Selectの中身をfor文で入れる
-
セレクトメニューで選択された...
-
onFocusOutが複数回呼ばれる!
-
セレクトメニューで最初から読...
-
現在時刻を取得してフォームのs...
-
【javascript・PHP】プルダウン...
-
jQueryで合計を出したい
-
slickのレスポンシブ > center...
-
一覧から選択した行の行番号を...
-
onchangeイベントを強制的に発...
-
return trueとreturn falseの用...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プルダウン 項目が多いので先頭...
-
Selectボックスの幅を自動で広...
-
jQuery セレクトボックスで選択...
-
セレクトを全て選択されていな...
-
【javascript・PHP】プルダウン...
-
JQuery selectが反映されない
-
CSVファイルを読みこみ、プルダ...
-
ブラウザの戻るボタンを押した...
-
selectタグに直接onChangeを書...
-
onFocusOutが複数回呼ばれる!
-
リストボックス間で値をコピー...
-
Selectの中身をfor文で入れる
-
javascriptでselectボックスの<...
-
リロード時もコンボボックスの...
-
リストボックスの項目の順番を...
-
getElementsByNameについて
-
現在時刻を取得してフォームのs...
-
セレクトの値を取得できない
-
<textarea>にプルダウンを表示...
-
フォームのメニューリストを外...
おすすめ情報