这里我有一段代码,我一直在调试Firebug。我想知道如何将参数foo
传递给函数getHoliday(param,param,param)
。这是我的XMLHttpRequest的代码块。
if (XMLHttpRequestObject.readyState==4 && XMLHttpRequestObject.status == 200)
{
var pp = null
var dd = null
var xmlResponse = XMLHttpRequestObject.responseXML;
var foo = new Array();
foo = parseXML(xmlResponse);
getHoliday(pp,dd,foo);
}
getHoliday
的前两个参数在此过程的后期才会被使用。我想首先使用数组getHoliday
中的数据加载foo
,以便将来我可以使用foo,如下所示。一旦我的断点到达getHoliday,脚本就会停止,所以我认为这是错误的参数。我想指出,pp
和dd
都不算什么,只是为空的未定义参数占位符。
function getHoliday(monthSelected,theday,names)
{
var HolidayName = new Array();
var holiday = ""
HolidayName = names;
monthSelected = monthSelected + 1;
for(var index = 0; HolidayName.length >= index; index++)
{
if(HolidayName[index] == monthSelected && HolidayName[index+1] == theday)
{
holiday = HolidayName[index+2]
}
}
return holiday
}
一旦我到了这里,我刚刚传递的names
数组就变得不确定了。为什么?以下是HolidayName
数组的外观。
HolidayName = new Array(2,4,"Party--12:00",2,22,"Eventalist Launch--6:00",2,18,"Play Day--12:00",3,17,"Play Day--12:00"););
警告foo
时结果为:
2,4,"Party--12:00",2,22,"Eventalist Launch--6:00",2,18,"Play Day--12:00",3,17,"Play Day--12:00"
这是parseXML
function parseXML(xmlData)
{
var aOutput=document.getElementById("testing2");
var events = xmlData.getElementsByTagName('year').length;
for(var i=0;i< events;i++)
{
var eYear = xmlData.getElementsByTagName('year')[i].firstChild.nodeValue;
var eMonth = xmlData.getElementsByTagName('month')[i].firstChild.nodeValue;
var eDay = xmlData.getElementsByTagName('day')[i].firstChild.nodeValue;
var eHour = xmlData.getElementsByTagName('hours')[i].firstChild.nodeValue;
var eMinute = xmlData.getElementsByTagName('minutes')[i].firstChild.nodeValue;
var eTitle = xmlData.getElementsByTagName('title')[i].firstChild.nodeValue;
var holiStr = '"' + eTitle + "--" + eHour +":"+ eMinute + '"';
setup.push(eMonth,eDay, holiStr);
}
return setup;
}
答案 0 :(得分:0)
根据您提供的信息,最好猜测:您的代码中的var foo是否较低? Javascript没有块级别的范围,这些被提升到函数顶部,而var foo lower可能会改变你的foo值。