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>&nbsp</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() в методе жизненного цикла созданного (), но с той же ошибкой.

Любое предложение? Спасибо

0 ответов

Другие вопросы по тегам