6

我在 angular5 应用程序中使用 arcgis-js-api 类型。当我尝试在多个组件中导入类型时,出现未捕获的引用错误:__esri 未定义。我已将 arcgis-js-api 包含到 tsconfig.app.json 文件中的类型数组中。这是我的代码。

  import { Component, OnInit, Input, ViewChild, ElementRef } from 
'@angular/core';
  import * as esriLoader from 'esri-loader';
  import { environment } from '../../../environments/environment';
  import Esri = __esri;

  @Component({
    selector: 'app-custom-widget',
    templateUrl: './custom-widget.component.html',
    styleUrls: ['./custom-widget.component.css']
  })
  export class CustomWidgetComponent implements OnInit {
    private _mapView: Esri.MapView;
    private _scriptOptions: any;

    @ViewChild('customWidget') widgetElement: ElementRef;
    @Input()
    set mapView(mapView: Esri.MapView) {
      if (!mapView) {
        return;
      }
      this._mapView = mapView;
      this.renderWidget();
    }
    get mapView(): Esri.MapView {
      return this._mapView;
    }

    constructor() {
      this._scriptOptions = {
        url: environment.arcgisAPIVersion
      };
    }

    ngOnInit() {

    }

    renderWidget(): void {
      esriLoader.loadModules([
        'esri/widgets/Widget'
      ], this._scriptOptions).then(([Widget]) => {
        const widgetProperties: Esri.WidgetProperties = {
          container: this.widgetElement.nativeElement
        };

        const widget: Esri.Widget = new Widget(widgetProperties);

        this._mapView.ui.add(widget, 'bottom-right');
      });
    }

  }
4

1 回答 1

0

我发现这个解决方案对我有用——
我创建了一个导入命名空间的模型文件,然后我在需要的地方使用了类型(有效地避免了错误“ReferenceError:__esri 未定义,不能在多个组件中使用这个命名空间” )。

示例:
在 esri.models.ts 文件中 -

import esri = __esri;  
export interface esriMapView extends esri.MapView {}
export interface esriLayerView extends esri.LayerView {}

在组件中-

import { esriMapView } from "../../modules/esri.models";
const mapView: esriMapView = new MapView({});
于 2021-05-30T06:11:29.467 回答