Я анализирую строку для некоторых данных, а затем создаю объекты из этих данных.Я могу нормально анализировать данные, но по какой-то причине мой код останавливается, когда я пытаюсь создать новый объект?Я подозреваю, что я делаю это неправильно, вот мой код:
Это мой класс даты чтения:
class ReadingDate {
year: number;
month: number;
day: number;
hour: number;
minute: number;
second: number;
public constructor(y: number, m: number,
d: number, h: number,
min: number, s: number) {
this.year = y;
this.month = m;
this.day = d;
this.hour = h;
this.minute = min;
this.second = s;
}
public toString() : string{
return (this.year+"-"+this.month+"-"+this.day+" "+this.hour+":"+this.minute+":"+this.second);
}
}
А вот фрагмент кода, в котором я пытаюсь создать новыйReadingDate в другом классе:
static parseDate(date: string){
console.log("parsing date"); // this prints fine
let array = date.split(" ", 2);
let dateArray = array[0].split("-", 3);
let timeArray = array[1].split(":", 3);
console.log("numbers \n1: " + parseInt(dateArray[0]) +" type: " + typeof(parseInt(dateArray[0]))
+"\n2: " + parseInt(dateArray[1]) + " type: " + typeof(parseInt(dateArray[1]))
+"\n3: " + parseInt(dateArray[2]) + " type: " + typeof(parseInt(dateArray[2]))
+"\n4: " + parseInt(timeArray[0]) + " type: " + typeof(parseInt(timeArray[0]))
+"\n5: " + parseInt(timeArray[1]) + " type: " + typeof(parseInt(timeArray[1]))
+"\n6: " + parseInt(timeArray[2]) + " type: " + typeof(parseInt(dateArray[2]))
);
console.log("parsed date"); // this prints fine
var parsedDate = new ReadingDate(
parseInt(dateArray[0]),
parseInt(dateArray[1]),
parseInt(dateArray[2]),
parseInt(timeArray[0]),
parseInt(timeArray[1]),
parseInt(timeArray[2])
);
console.log("reached here"); //this never prints
console.log("newlyParsedDate: "+ parsedDate.toString()); //this never prints
return parsedDate; //this never happens
}
И вот пример того, как я вызываю parseDate ():
static parseReading(reading: string) {
console.log("inparser: "+reading);
let array = reading.split(",", 4);
let date = ParserProvider.parseDate(array[0]);
console.log("finished parsing date"); //this does not print and nothing past it happens
let location = array[1];
let val = array[2]==1?true:false;
let battery = array[3];
console.log("inparser: "+location,val,battery); //does not print
}
С примером даты "2018-10-16 10:32:02 "вывод консоли выглядит следующим образом:
parser.ts:17 inparser: 2018-10-16 10:41:22,living,1,16
parser.ts:31 parsing date
parser.ts:33 2018-10-16
parser.ts:34 10:32:02
parser.ts:37 parsed date
parser.ts:38 numbers
1: 2018 type: number
2: 10 type: number
3: 16 type: number
4: 10 type: number
5: 32 type: number
6: 2 type: number
Это не дает мне никаких ошибок, но моя программа просто перестает делать что-либо после того, как я пытаюсь сделать объект ReadingDate.
Заранее благодарим за помощь!
РЕДАКТИРОВАТЬ: обновляется методом toString
РЕДАКТИРОВАТЬ 2: обновляется с примером вызова parseDate, некоторыми дополнительными console.logs ивывод консоли, когда он называется
РЕДАКТИРОВАТЬ 3: Хорошо, поэтому, когда я помещаю попытку / ловлю вокруг, где я пытаюсь сделать объект следующим образом:
try{var parsedDate = new ReadingDate(
parseInt(dateArray[0]),
parseInt(dateArray[1]),
parseInt(dateArray[2]),
parseInt(timeArray[0]),
parseInt(timeArray[1]),
parseInt(timeArray[2])
);}
catch(error){console.log(error);}
, я получаю эту ошибку:
ReferenceError: ReadingDate is not defined
at Function.webpackJsonp.197.ParserProvider.parseDate (VM14753 main.js:300)
at Function.webpackJsonp.197.ParserProvider.parseReading (VM14753 main.js:276)
at HomePage.webpackJsonp.195.HomePage.handleReading (VM14753 main.js:146)
at VM14753 main.js:141
at VM14752 vendor.js:75337
at Array.forEach (<anonymous>)
at Events.publish (VM14752 vendor.js:75336)
at ClientImpl.MqttProvider.onMessageArrived (VM14753 main.js:228)
at ClientImpl.LibraryFactory.ClientImpl._receiveMessage (VM14750 paho-mqtt.js:1502)
at ClientImpl.LibraryFactory.ClientImpl._receivePublish (VM14750 paho-mqtt.js:1477)
РЕДАКТИРОВАТЬ 4: Исправлено!См. Мой ответ ниже и обратитесь к этому вопросу StackOverflow здесь