JSでセレクトボックスの内容を切り替えたい
年末を向かえましたが、クリアできない問題を抱えて焦っています。
あるショッピングサイトを構築しておりますが、
商品詳細ページでカラーを選択するとそれに対応したサイズを
表示させたいと思っています。
カラー、サイズ共に異なるセレクトボックスを使用しております。
//サンプルデータ(2次元配列)
var dataStock = new Array(new Array("ブラック", "S", 2),
new Array("ブラック", "M", 3),
new Array("ホワイト", "S", 1),
new Array("ホワイト", "M", 2),
new Array("ホワイト", "L", 1),
new Array("レッド", "M", 3),
new Array("レッド", "L", 2));
var dataSize = new Array();
//----------------- とりあえずデータ表示 -----------------
document.write("<table border='1'>");
for(i=0; i<data.length; i++) {
document.write("<tr>");
for(n=0; n<data[i].length; n++) {
document.write("<td>"+data[i][n]+"</td>");
}
document.write("</tr>");
}
document.write("</table><br /><br />");
//----------------- カラー表示 -----------------
document.write("<select name='color' onchange=getNo2(this.value);>");
for(i=0; i<data.length; i++) {
document.write("<option value='"+data[i][0]+"'>"+data[i][0]+"</option>");
}
document.write("</select><br /><br />");
//----------------- サイズ表示 -----------------
function getNo2(color) {
document.write("<select name='size'>");
for(i=0; i<data.length; i++) {
//↓2次元配列から選択したカラーの情報を取得
if(color == data[i][0]) {
dataSize[i] = data[i][1];
document.write("<option value='"+dataSize[i]+"'>"+dataSize[i]+"</option>");
}
}
document.write("</select>");
}
上記処理だと、「対応したカラーのサイズを表示する」という
目的は達成できますが、カラーを選択すると
ページ全部がサイズに上書きされ、サイズのセレクトボックスしか
表示されません。
当たり前ですが・・・
いろいろ試してみましたが、どれもうまく行きませんでした。
何か良いアドバイスがあればご教授下さい。
よろしくお願い致します。
お礼
メーカーがどこだかわからないMTBに乗っていたのですが、サイズなど気にもせず乗っていました。 私の住むところでは、現物にお目にかかれそうもありません・・・。 回答ありがとうございました。