0

在这里,我有一段代码,我一直在通过 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;
}
4

1 回答 1

0

鉴于您提供的信息,最好的猜测:代码中是否有 var foo ?Javascript 没有块级作用域,这些被提升到函数的顶部,而 var foo lower 可能会改变你的 foo 值。

于 2013-02-27T02:31:26.057 回答