Aurelia TypeError: document.getElementById(...) имеет значение null, это только при загрузке первой страницы
Я использую фреймворк aurelia и браузер Firefox. Я получил это сообщение об ошибке, когда страница загружается в первый раз: "TypeError: document.getElementById(...) имеет значение null"
Вот машинописный код с надрезом:
import { EventAggregator } from 'aurelia-event-aggregator';
import { HistoricalViewAll } from "./hist-view-all";
import { DeviceData } from "./model/device-data";
import { DeviceLocDataDTO } from "./dto/device-loc-data-dto";
import { activationStrategy } from 'aurelia-router';
import { autoinject } from 'aurelia-framework';
import { View } from "aurelia-framework";
const AWS = ( window as any ).AWS;
@autoinject( EventAggregator )
@autoinject( HistoricalViewAll )
@autoinject( DeviceData )
@autoinject( DeviceLocDataDTO )
export class HistoricalViewSingle {
// any declarations...
constructor(private histDeviceDataDto: HistoricalViewAll, private deviceData: DeviceData, private deviceDataDTO: DeviceLocDataDTO, private ea: EventAggregator) {
console.log( "HistoricalViewSingle constructor called..." );
this.location = "Zurich";
this.deviceSelection = "allDevices";
}
determineActivationStrategy() {
console.log( "determineActivationStrategy() called..." );
return activationStrategy.replace;
}
activate( params, routeConfig, navigationInstruction ) {
this.params = params;
console.log( "params: " );
console.log( params );
this.routeConfig = routeConfig;
console.log( "routeConfig in HistoricalViewSingle: " );
console.log( this.routeConfig );
this.routeConfig.navModel.setTitle = this.params.device;
console.log( this.params.device.substr( 3, 2 ) );
this.deviceInURL = params.device;
console.log( this.deviceInURL );
//necessary to get first the data before UI will be renderet...
return this.deviceDataDTO.postReqDeviceDataFromLocation( "devices-in-location", this.location, this.deviceSelection );
}
attached() {
console.log( "HistoricalViewSingle is attached..." );
this.deviceLocationList = this.deviceDataDTO.getDeviceLocationList();
this.deviceLocationHint = "Übersicht Filiale " + this.locationName;
if ( this.deviceLocationList.length != 0 ) {
this.noDeviceHint = "devDataOk"
this.setDeviceSelection( this.deviceInURL );
} else {
this.noDeviceHint = "Keine Sensordaten"
}
this.changeTimeWindow( 1 );
}
created(owningView, myView) {
console.log("created() call in HistoricalViewSingle");
console.log(myView);
//this.changeTimeWindow( 1 );
}
changeTimeWindow( hours: number ) {
var deviceId: string = this.selectedDevLocList[0].device_id;
console.log("DeviceKey in changeTimeWindow(): " + deviceId);
console.log(document.getElementById( 'chart-' + deviceId) + ' - chart-' + deviceId);
const ctx1: CanvasRenderingContext2D = ( document.getElementById( 'chart-' + deviceId ) as any ).getContext( '2d' );
this.histDeviceDataDto.changeTimeWindowForOneDevice( hours, deviceId, ctx1 );
}
}
Ошибка будет вызвана в этой строке:
const ctx1: CanvasRenderingContext2D = ( document.getElementById( 'chart-' + deviceId ) as any ).getContext( '2d' );
Вот HTML-код:
<template> <require from="./hist-view-all"></require>
<div class="col-sm-12">
<h1>
<span id="filiale">${deviceLocationHint}</span>
</h1>
<div repeat.for="deviceData of deviceLocationList">
<div class="pull-left">
<button class="btn btn-link btn-block" click.delegate="setDeviceSelection(deviceData.device_id)">${deviceData.device_id}</button>
</div>
</div>
<h3> </h3>
<div class="margin">
<div class="btn-group" role="group" aria-label="..." if.bind="noDeviceHint === 'devDataOk'">
<button name="defaultbutton" type="button" click.delegate="changeTimeWindow(1)" class="btn btn-default">1h</button>
<button type="button" click.delegate="changeTimeWindow(8)" class="btn btn-default">8h</button>
<button type="button" click.delegate="changeTimeWindow(24)" class="btn btn-default">1d</button>
<button type="button" click.delegate="changeTimeWindow(120)" class="btn btn-default">5d</button>
</div>
<div class="device-container">
<div repeat.for="deviceData of selectedDevLocList">
<div class="panel panel-default">
<div class="panel-heading">
<h2 class="panel-title">${deviceData.boardType}</h2>
<small>${deviceData.locationName} ${deviceData.room}</small>
</div>
<div class="panel-body">
<canvas class="chart" id="chart-${deviceData.device_id}"></canvas>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
после первой загрузки страницы я нажимаю кнопку "8h", например, я не получаю сообщение об ошибке, и данные на диаграмме chartjs будут отображены нормально. Идентификатор canvas может быть чем-то вроде этого "chart-am-ZH-Office", и он будет корректным при первой загрузке страницы. Я пытался также вызвать метод changeTimeWindow() в методе жизненного цикла созданного (), но с той же ошибкой.
Любое предложение? Спасибо