Javascript - 尝试将函数的结果保存到对象。对象为空

时间:2014-07-18 13:59:07

标签: javascript

在一个名为searchXML的分离函数中,传入一些参数,我正在解析一个xml文件,根据参数返回一些特定的值,并将这些值保存到一个对象中。然后,在另一个函数中,调用searchXML()并将结果保存到对象。不幸的是,这个对象变成了空洞。我是javascript的新手,所以我不确定它的逻辑或语法是否导致错误。

xml采用以下格式:

<?xml version="1.0" encoding="UTF-8"?>
<Root>  
<Row>
    <Tab>MF_Act</Tab>
    <Category>Product Store Sessions </Category>
    <_2013_01_31>1</_2013_01_31>
    <_2013_02_28>2</_2013_02_28>
    <_2013_03_31>3</_2013_03_31>
    <_2013_04_30>4</_2013_04_30>
    <_2013_05_31>5</_2013_05_31>
    <_2013_06_30>6</_2013_06_30>
    <_2013_07_31>7</_2013_07_31>
    <_2013_08_31>8</_2013_08_31>
    <_2013_09_30>9</_2013_09_30>
    <_2013_10_31>10</_2013_10_31>
    <_2013_11_30>11</_2013_11_30>
    <_2013_12_31>12</_2013_12_31>
    <FY_2013>x</FY_2013>
    <_2014_01_31>1</_2014_01_31>
    <_2014_02_28>2</_2014_02_28>
    <_2014_03_31>3</_2014_03_31>
    <_2014_04_30>4</_2014_04_30>
    <_2014_05_31>5</_2014_05_31>
    <_2014_06_30>6</_2014_06_30>
    <_2014_07_31>7</_2014_07_31>
    <_2014_08_31>8</_2014_08_31>
    <_2014_09_30>9</_2014_09_30>
    <_2014_10_31>10</_2014_10_31>
    <_2014_11_30>11</_2014_11_30>
    <_2014_12_31>12</_2014_12_31>
    <FY_2014>y</FY_2014>
</Row>
<Row>
    <Tab>MF_Act</Tab>
    <Category>YTD</Category>
    <_2013_01_31>1</_2013_01_31>
    <_2013_02_28>2</_2013_02_28>
    <_2013_03_31>3</_2013_03_31>
    <_2013_04_30>4</_2013_04_30>
    <_2013_05_31>5</_2013_05_31>
    <_2013_06_30>6</_2013_06_30>
    <_2013_07_31>7</_2013_07_31>
    <_2013_08_31>8</_2013_08_31>
    <_2013_09_30>9</_2013_09_30>
    <_2013_10_31>10</_2013_10_31>
    <_2013_11_30>11</_2013_11_30>
    <_2013_12_31>12</_2013_12_31>
    <FY_2013>r</FY_2013>
    <_2014_01_31>1</_2014_01_31>
    <_2014_02_28>2</_2014_02_28>
    <_2014_03_31>3</_2014_03_31>
    <_2014_04_30>4</_2014_04_30>
    <_2014_05_31>5</_2014_05_31>
    <_2014_06_30>6</_2014_06_30>
    <_2014_07_31>7</_2014_07_31>
    <_2014_08_31>8</_2014_08_31>
    <_2014_09_30>9</_2014_09_30>
    <_2014_10_31>10</_2014_10_31>
    <_2014_11_30>11</_2014_11_30>
    <_2014_12_31>12</_2014_12_31>
    <FY_2014>t</FY_2014>
</Row>

</Root>

我的searchXML代码:

function searchXML(xml, goalTab, goalCategory){
    console.log('in search xml');
    //get the current year in 4 digits (yyyy)
    var year = new Date().getFullYear();

    //gets the string value of the 2 digit number of the previous completed month (ie: currMonth = April (04), prevMonth = March (03))
    var prevMonth = new Date().getMonth().toString(); 
    if(prevMonth.toString().length == 1){
        prevMonth = '0'+prevMonth.toString();
    }

    //check for leap year
    if(year % 4 == 0){
        var feb = 29;
    }else{
        var feb = 28;
    }

    //make array for number of days per month in this year
    var daysInMonths = [31, feb, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];


    //get the row offset for the particular month
    var rowOffset_Month = (year - 2013)*12 + 2 + parseInt(prevMonth); 

    var result = null;

    $(xml).find('Row').each(function(){ // for each Row in xml
        console.log('-------new row------')
        var row = this;
        var boolTab = $(row).find('Tab').text() == goalTab; 
        var boolCategory = $(row).find('Category').text() == goalCategory;
        console.log(boolCategory);
        console.log(boolTab);

        if (boolCategory && boolTab) {
            console.log('found match');
           var result= {
                //get the row that corresponds with the calculated row offset
                //month : arr[rowOffset_Month][i],
                month : $(row).find('_'+year+'_'+prevMonth+'_'+daysInMonths[parseInt(prevMonth) - 1]).text(), //-----------------check for errors here--------------------

                //get the last row, which corresponds with the 2014 ytd 
                // ytd : arr[arr[1].length - 1][i] 
                ytd : $(row).find('FY_' + year).text() //-----------------check for errors here--------------------
            }; //END result obj
        };// END if
    });// END jquery function

    return result;
};

然后是一个单独的功能:

var ann_appStarts_plan = searchXML(xml, "MF_Act", "Product Store Sessions ");
console.log('plan month: ' + ann_appStarts_plan.month);
console.log('plan ytd: ' + ann_appStarts_plan.ytd);

Firebug中的错误:

TypeError: ann_appStarts_plan is null
    console.log('plan month: ' + ann_appStarts_plan.month);

2 个答案:

答案 0 :(得分:1)

您在回调函数中重新声明result可能是个问题,但我不确定.find()方法的作用。如果它是异步的,那么总体代码无论如何都不会起作用。

在此处取走var

       var result= {

这使得另一个变量,一个在回调中。

答案 1 :(得分:1)

你正在创造一个&#34;外部&#34; result

var result = null;

$(xml).find('Row').each(function(){ // for each Row in xml
 // ...

然后分配给新的&#34;内部&#34; result

if (boolCategory && boolTab) {
        console.log('found match');
       var result= {
        // ..
       };

然后丢弃,我们返回原始文件:

return result;

丢失了作业中的var

if (boolCategory && boolTab) {
  result= {
    month : $(row).find('_'+year+'_'+prevMonth+'_'+daysInMonths[parseInt(prevMonth) - 1]).text(), 

    ytd : $(row).find('FY_' + year).text() 
  };

  return false;
};

然后返回false退出each()循环,因为已找到匹配项(each()将为列表中的每个对象调用内部函数一次on,但如果内部函数返回false)将停止。