5

我使用这个种子开始使用 Angular 2 Typescript 和 Webpack:https ://github.com/haoliangyu/angular2-leaflet-starter 。

我对大多数使用的工具和技术(Angular 2、Typescript、Webpack)都很陌生。虽然我对这些了解越来越多,但似乎我仍然没有掌握如何包含第三方非类型化 JS 库

我想将leaflet-routing-machine.js包含到我的项目中。据我所知,虽然传单确实存在分型,但传单路由机不存在分型。

我通过安装包npm install并添加了所需的快速启动代码,以显示路线。

地图服务.ts

/// <reference path="../../typings/leaflet/leaflet.d.ts"/>

import {Injectable} from 'angular2/core';
import {Map} from 'leaflet';

Injectable()
export class MapService {
  map: Map; // holds reference to the normal leaflet map object

  showRoute(){
        L.Routing.control({
        waypoints: [
            L.latLng(47.569198, 7.5874886),
            L.latLng(47.5685418, 7.5886755)
        ]
    }).addTo(this.map);

  }

}

我遇到的错误npm start是:

ERROR in ./app/services/map.service.ts
(56,11): error TS2339: Property 'Routing' does not exist on type 'typeof L'.

据我了解,我不应该在 index.html 中包含 JS 文件,因为这应该由 webpack 自动完成。除了我通常不确定如何在没有打字的情况下包含第三方库(这样的答案没有帮助)这一事实之外,我的情况似乎有点不同,因为LObject 是标准传单并且不知道该Routing属性。我以某种方式理解,因为我看不到路由机器库如何扩展传单库。

有什么建议么?

4

2 回答 2

1

我没有使用过 Angular 2,也没有使用过 TypeScript,但我怀疑 TypeScript 不喜欢 LRM 将自身附加到L对象/命名空间。

请注意,LRM 也将自身导出为普通的 CommonJS 模块,因此您可以执行以下操作而不是使用L.Routing.Control

var L = require('leaflet');
var Routing = require('leaflet-routing-machine');

var map = L.map(...);
var routingControl = Routing.control({ ... });
于 2016-06-08T06:31:53.100 回答
0

这一直是我挣扎了一段时间,但最终得到了它的工作。这是您导入它的方式:

import * as L from 'leaflet'; import 'leaflet-routing-machine';

在你的 systemjs.config

   map: {
    'leaflet': 'npm:leaflet/dist/leaflet.js',
}
     packages: {
           leaflet: {
              defaultExtension: 'js'
              }
            }

要在组件中设置路线,请确保将路线添加到地图而不是切片图层。

    ngAfterViewInit() {

     var map = new L.Map("map")

    let openmap = L.tileLayer("http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", {
        attribution: 'Map data © <a href="http://openstreetmap.org">OpenStreetMap</a> ',
       }).addTo(map);

    let route = L.Routing.control({
        waypoints: [
          L.latLng(40.5663651,-75.6032277),
          L.latLng(40.00195, -76.073299),
          L.latLng(42.3673945,-83.0750408)
        ]
      }).addTo(map);}

关于这个问题,我得到了很多信息: How to import a module that extends another on the same namespace

于 2018-02-06T20:16:32.827 回答