通过Javascript中的参数传递变量

时间:2013-02-26 23:59:26

标签: javascript arrays debugging parameters xmlhttprequest

这里我有一段代码,我一直在调试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,脚本就会停止,所以我认为这是错误的参数。我想指出,ppdd都不算什么,只是为空的未定义参数占位符。

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;
}

1 个答案:

答案 0 :(得分:0)

根据您提供的信息,最好猜测:您的代码中的var foo是否较低? Javascript没有块级别的范围,这些被提升到函数顶部,而var foo lower可能会改变你的foo值。