[英]Dynamics CRM 2011: javascript, 'null' is null not an object. error
[英]Javascript - Trying to save the result of a function to an object. Object is null
在一個名為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);
盡管我不確定.find()
方法的作用,但您在該回調函數中重新聲明result
可能是問題.find()
。 如果它是異步的,那么總的代碼將無法正常工作。
在這里拿走var
:
var result= {
這將產生另一個變量,即回調中的一個。
您正在創建“外部” result
:
var result = null;
$(xml).find('Row').each(function(){ // for each Row in xml
// ...
然后分配給新的“內部” 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()
將為其調用的列表中的每個對象調用一次內部函數,但是如果內部函數曾經返回false
,則將停止)。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.