繁体   English   中英

相互依存 <select>使用JavaScript

[英]Inter-dependent <select>s with JavaScript

我有一个日期的javascript数组,形式为

{year:'2010',month:'6',day:'23'}

我需要连续三个<select> ,第一个填充列表中的年份,第二个填充第一个选择的年份中的月份,第三个填充与所选年份对应的天,月。

我无权访问jQuery之类的库。

处理此问题的最佳方法是什么?

要检索年份数据以设置初始选择,您必须至少遍历一次数组(希望仅遍历一次)。

由于事实上您希望根据第二个和第一个填充第二个选择,以响应第一个和第三个填充,因此您需要一种快速的方法来引用它们。

我最初会填充选择内容,同时将数据整理到更易于检索的系统中。 我在这里使用带有键的数组,其他人可能建议最好使用带键的对象。

/* Global variables */
var arr = new Array({year:'2010',month:'6',day:'23'},
                    {year:'2011',month:'6',day:'23'},
                    {year:'2010',month:'5',day:'23'});
var srt = new Array();

function populateArrs()
{
for(var i=0;i<arr.length;i++)
{
  var y = arr[i].year;
  var m = arr[i].month;
  var d = arr[i].day;
  var in_select = false;

  /* Month array, day array */
  var mArr;
  var dArr;

  if(srt[y] != null)
  {
    mArr = srt[y];
    in_select = true;
  }
  else
    mArr = new Array();


  if(mArr[m] != null)
    dArr = mArr[m];
  else
    dArr = new Array();

  if(dArr[d] == null)
    dArr[d] = d;
  /* No else as at this stage it will already exist in array set */

  mArr[m] = dArr;
  srt[y] = mArr;

  /* Don't duplicate values in the select */
  if(!in_select) 
  {
    var opt = document.createElement('option');
    opt.value = y;
    opt.text = y;
    /* Get your year select */
    var ySel = document.getElementById('year_select'); 
    ySel.appendChild(opt);
  }
}
}

if (window.addEventListener)
  window.addEventListener("load", populateArrs, false);
else if (window.attachEvent)
  window.attachEvent("onload", populateArrs);

之后,您需要设置onclick事件以动态填充其他选择。 您可以使用查找和for..in循环简单地引用适当的数组。

月份:

var ySel = document.getElementById('year_select');
var mArr = srt[ySel.options[ySel.selectedIndex].value];
for( x IN mArr)
  /* Populate month select */

天:

/*As above, then */
var mSel = document.getElementById('month_select');
var dArr = srt[mSel.options[mSel.selectedIndex].value];

希望能有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM