所以,我尝试了解其他问题如何处理包含jQuery插件的问题。但首先让我们从基础知识开始。
首先,我安装了jQuery插件。
npm i jquery
然后,我添加了TypeScript定义。
npm install -d @types/jquery
我将它包含在我的脚本数组中。
"apps": [{
...
"scripts": [
"../node_modules/jquery/dist/jquery.min.js",
],
...
}]
然后,我尝试了一下它是否有效。
import { Component, OnInit} from '@angular/core';
import * as $ from 'jquery';
@Component({
selector: 'app-ww-inventory-map',
templateUrl: './ww-inventory-map.component.html',
styleUrls: ['./ww-inventory-map.component.scss']
})
export class WwInventoryMapComponent implements OnInit {
constructor() { }
ngOnInit() {
$(window).click(function () {
alert('ok');
});
}
}
响应很快地到来了...
到目前为止,一切顺利。第一个工作包已经完成,是时候继续了。我安装了jQuery插件mapael。npm i jquery-mapael
angular-cli.json
"apps": [{
...
"scripts": [
"../node_modules/jquery/dist/jquery.min.js",
"../node_modules/jquery-mapael/js/jquery.mapael.min.js",
"../node_modules/jquery-mousewheel/jquery.mousewheel.js"
],
...
}]
之后我尝试了这个。基于官方页面上看到的代码示例 https://www.vincentbroute.fr/mapael/#basic-code-example
import { Component, OnInit } from '@angular/core';
import * as $ from 'jquery';
declare global {
interface JQuery {
mapael(map: any): JQuery;
}
}
@Component({
selector: 'app-ww-inventory-map',
templateUrl: './ww-inventory-map.component.html',
styleUrls: ['./ww-inventory-map.component.scss']
})
export class WwInventoryMapComponent implements OnInit {
constructor() { }
ngOnInit() {
$(".container").mapael({
map: {
name: "world_countries"
}
});
}
}
一开始看起来一切正常,没有警告或问题显示,但当我加载页面时...
所以,我不知道如何正确地做这件事。我希望能想办法解决这个问题。但是其他几个例子都没有对我有太大的帮助。我很抱歉,知道已经有类似的问题,但我真的无法让它正常工作。
编辑1:我尝试的第一个解决方案来自Naga Sai A,但在我的端上需要进行一些更改,以便编译器不会抱怨。谢谢,Naga Sai A!
我的.ts看起来没问题
import { Component, OnInit } from '@angular/core';
import * as $ from 'jquery';
import 'jquery-mapael';
import 'jquery-mapael/js/maps/world_countries.js';
declare global {
interface JQuery {
mapael(map: any): JQuery;
}
}
@Component({
selector: 'app-ww-inventory-map',
templateUrl: './ww-inventory-map.component.html',
styleUrls: ['./ww-inventory-map.component.scss']
})
export class WwInventoryMapComponent implements OnInit {
constructor() { }
ngOnInit() {
$(".container").mapael({
map: {
name: "world_countries"
}
});
}
}
编辑2:彼得的解决方案占位符
导入是正确的,但组件仍需要这些导入。此外,不需要包括Raphael.js。至少我没有,地图工作得很好。我的设置没有改变。此外,我保留了最初的声明方式。