Pro*_*ime 6 javascript frontend leaflet typescript ecmascript-6
我目前正在尝试在个人项目中加载传单地图。但由于导入问题,我的代码无法执行。我使用以下命令安装了传单类型定义
npm install --save @types/leaflet
Run Code Online (Sandbox Code Playgroud)
它有一个依赖项,所以我也安装了 geojson
npm install --save @types/geojson
Run Code Online (Sandbox Code Playgroud)
这是我的 tsconfig.json 文件的一部分
{
"compilerOptions": {
"typeRoots": ["node_modules/@types"],
"rootDir": ".",
"outDir": "build",
"target": "es2018",
"lib": [
"es2018",
"dom"
],
"types": [
"leaflet",
"geojson"
]
},
"include": [
"src/**/*.ts"
],
"exclude": [
"node_modules"
]
}
Run Code Online (Sandbox Code Playgroud)
我遵循传单文档中的基本示例,但我没有编写内联代码,而是创建了一个类。
这是索引的一部分,我在其中加载所有 js 文件,地图 div 位于主体内部(此处未显示)。
<link rel="stylesheet" type="text/css" href="ts\node_modules\leaflet\dist\leaflet.css">
<script src="ts\node_modules\leaflet\dist\leaflet.js"></script>
<script src="./ts/build/src/mapsmanager.js" type="module"></script>
<script type="module">
// Import classes
import { MapsManager } from './ts/build/src/mapsmanager.js';
initialize();
function initialize()
{
/* ADD MAP SCRIPT */
let mapsman = new MapsManager();
}
</script>
Run Code Online (Sandbox Code Playgroud)
这是我的mapsmanager.ts 文件,我从中得到错误
import * as Leaf from 'leaflet';
export class MapsManager
{
/*DO STUFF*/
}
Run Code Online (Sandbox Code Playgroud)
这条线
import * as Leaf from 'leaflet';
Run Code Online (Sandbox Code Playgroud)
给我以下运行时错误:
TypeError: Error resolving module specifier: leaflet
Run Code Online (Sandbox Code Playgroud)
我还尝试将传单作为模块加载
<script src="ts\node_modules\leaflet\dist\leaflet.js" type="module"></script>
Run Code Online (Sandbox Code Playgroud)
但它不起作用,它给了我另一个运行时错误:
TypeError: t is undefined (inside leaflet.js)
Run Code Online (Sandbox Code Playgroud)
重要的是 ,在不使用类的情况下,通过在索引内使用内联 JS,地图可以正常工作。它可能与项目配置/声明/定义/模块内容甚至传单有关。
这是我的 package.json 的一部分
"files": [
"build",
"src"
],
"devDependencies": {
"gts": "^2.0.0",
"typescript": "~3.8.0",
"@types/node": "^10.0.3"
},
"dependencies": {
"@types/geojson": "^7946.0.7",
"@types/leaflet": "^1.5.12",
"leaflet": "^1.6.0"
}
Run Code Online (Sandbox Code Playgroud)
我还尝试添加一个index.d.ts 文件,在其中放置传单模块的声明,因为在传单之前我尝试使用使用此方法的Google Maps JS API,但它不起作用。
我希望我对问题的描述是详尽的
import该问题很可能是由您的架构中的两种不同用途引起的:
对于 TypeScript 转译步骤,转译器知道绝对路径(“传单”)可以位于项目的“node_modules”文件夹中。
但浏览器模块导入的情况并非如此:这里您需要指定文件的确切(可能是相对)路径(或至少是模块 package.json 文件的位置),类似于您指定的内容在标签src的属性中<script>。
在这种情况下,您必须修改“导入传单”路径,以便最终的JS文件具有正确的路径。
由于这可能会破坏第 1 步 TypeScript,因此您需要更新 tsconfig 以告诉 TypeScript 如何解析该路径。请参阅TypeScript 导入路径别名
注意:通常这不是问题,因为很少有人真正在浏览器模块导入中使用,而是使用构建引擎(可以包含 TypeScript 转换步骤)将所有 JS捆绑在单个文件中(例如 webpack 或 Rollup),因此解析全部在构建阶段完成,您可以配置所有解析器,以便它们查看您的“node_modules”文件夹(显然是默认行为,因此通常不需要特殊配置)。
| 归档时间: |
|
| 查看次数: |
9750 次 |
| 最近记录: |