在 angular 2 延迟加载模块中使用外部 javascript 库,而不是 index.html
Using external javascript libraries in angular 2 lazy loaded module, not index.html
所以我想在我的 Angular 2 应用程序中包含一个外部 JS 库,在这种情况下是一个旋转木马滑块。我看过很多说明如何添加它的教程我已经成功完成了,但是在 index.html.
上引用了库
如您所知,每次访问应用程序时都会加载库,无论他们是否访问需要轮播的组件。因为它很重,我只想在需要的地方加载它,这是在一个延迟加载的模块中。
我没试过,但我确定我可以在使用它的组件中删除脚本标签,但我觉得这不合适。
一定有正确的方法。这是什么!?
谢谢!
这实际上取决于您尝试加载的库类型以及您在应用程序中使用的模块加载器。
我假设您使用的是 Typescript 或至少是 ES6 语法。
如果您的第 3 方依赖项是 AMD/UMD/CommonJS 模块
在这种情况下,您可以在组件文件之上导入它。
import {SomeClassName} from "path/to/library";
如果您的第 3 方是全局模块(例如:JQuery 插件)
在这种情况下,您只需导入 js 文件,它将在全局变量上可用。
import "path/to/library";
结论
无论如何,您应该检查第 3 方库是否已经有可用的类型,如果您使用的是 Typescript,这将对您有所帮助。
根据您的模块加载器,您可能需要在此之前进行一些配置。但是没有更多信息很难帮到你。
最好的,
jpsfs
我们正在我们的一个项目中这样做以动态加载 js 库
ScriptStore.ts 将在本地或远程服务器上包含脚本的 path 和 将用于动态加载脚本的名称
interface Scripts {
name: string;
src: string;
}
export const ScriptStore: Scripts[] = [
{name: 'filepicker', src: 'https://api.filestackapi.com/filestack.js'},
{ name: 'rangeSlider', src: '../../../assets/js/ion.rangeSlider.min.js' }
];
script.service.ts 是一个可注入服务,它将处理脚本的加载,按原样复制 script.service.ts
import {Injectable} from "@angular/core";
import {ScriptStore} from "./script.store";
declare var document: any;
@Injectable()
export class Script {
private scripts: any = {};
constructor() {
ScriptStore.forEach((script: any) => {
this.scripts[script.name] = {
loaded: false,
src: script.src
};
});
}
load(...scripts: string[]) {
var promises: any[] = [];
scripts.forEach((script) => promises.push(this.loadScript(script)));
return Promise.all(promises);
}
loadScript(name: string) {
return new Promise((resolve, reject) => {
//resolve if already loaded
if (this.scripts[name].loaded) {
resolve({script: name, loaded: true, status: 'Already Loaded'});
}
else {
//load script
let script = document.createElement('script');
script.type = 'text/javascript';
script.src = this.scripts[name].src;
if (script.readyState) { //IE
script.onreadystatechange = () => {
if (script.readyState === "loaded" || script.readyState === "complete") {
script.onreadystatechange = null;
this.scripts[name].loaded = true;
resolve({script: name, loaded: true, status: 'Loaded'});
}
};
} else { //Others
script.onload = () => {
this.scripts[name].loaded = true;
resolve({script: name, loaded: true, status: 'Loaded'});
};
}
script.onerror = (error: any) => resolve({script: name, loaded: false, status: 'Loaded'});
document.getElementsByTagName('head')[0].appendChild(script);
}
});
}
}
在任何需要的地方注入这个 ScriptService
并像这样加载 js 库
this.script.load('filepicker', 'rangeSlider').then(data => {
console.log('script loaded ', data);
}).catch(error => console.log(error));
所以我想在我的 Angular 2 应用程序中包含一个外部 JS 库,在这种情况下是一个旋转木马滑块。我看过很多说明如何添加它的教程我已经成功完成了,但是在 index.html.
上引用了库如您所知,每次访问应用程序时都会加载库,无论他们是否访问需要轮播的组件。因为它很重,我只想在需要的地方加载它,这是在一个延迟加载的模块中。
我没试过,但我确定我可以在使用它的组件中删除脚本标签,但我觉得这不合适。
一定有正确的方法。这是什么!?
谢谢!
这实际上取决于您尝试加载的库类型以及您在应用程序中使用的模块加载器。
我假设您使用的是 Typescript 或至少是 ES6 语法。
如果您的第 3 方依赖项是 AMD/UMD/CommonJS 模块
在这种情况下,您可以在组件文件之上导入它。
import {SomeClassName} from "path/to/library";
如果您的第 3 方是全局模块(例如:JQuery 插件)
在这种情况下,您只需导入 js 文件,它将在全局变量上可用。
import "path/to/library";
结论
无论如何,您应该检查第 3 方库是否已经有可用的类型,如果您使用的是 Typescript,这将对您有所帮助。
根据您的模块加载器,您可能需要在此之前进行一些配置。但是没有更多信息很难帮到你。
最好的, jpsfs
我们正在我们的一个项目中这样做以动态加载 js 库
ScriptStore.ts 将在本地或远程服务器上包含脚本的 path 和 将用于动态加载脚本的名称
interface Scripts {
name: string;
src: string;
}
export const ScriptStore: Scripts[] = [
{name: 'filepicker', src: 'https://api.filestackapi.com/filestack.js'},
{ name: 'rangeSlider', src: '../../../assets/js/ion.rangeSlider.min.js' }
];
script.service.ts 是一个可注入服务,它将处理脚本的加载,按原样复制 script.service.ts
import {Injectable} from "@angular/core";
import {ScriptStore} from "./script.store";
declare var document: any;
@Injectable()
export class Script {
private scripts: any = {};
constructor() {
ScriptStore.forEach((script: any) => {
this.scripts[script.name] = {
loaded: false,
src: script.src
};
});
}
load(...scripts: string[]) {
var promises: any[] = [];
scripts.forEach((script) => promises.push(this.loadScript(script)));
return Promise.all(promises);
}
loadScript(name: string) {
return new Promise((resolve, reject) => {
//resolve if already loaded
if (this.scripts[name].loaded) {
resolve({script: name, loaded: true, status: 'Already Loaded'});
}
else {
//load script
let script = document.createElement('script');
script.type = 'text/javascript';
script.src = this.scripts[name].src;
if (script.readyState) { //IE
script.onreadystatechange = () => {
if (script.readyState === "loaded" || script.readyState === "complete") {
script.onreadystatechange = null;
this.scripts[name].loaded = true;
resolve({script: name, loaded: true, status: 'Loaded'});
}
};
} else { //Others
script.onload = () => {
this.scripts[name].loaded = true;
resolve({script: name, loaded: true, status: 'Loaded'});
};
}
script.onerror = (error: any) => resolve({script: name, loaded: false, status: 'Loaded'});
document.getElementsByTagName('head')[0].appendChild(script);
}
});
}
}
在任何需要的地方注入这个 ScriptService
并像这样加载 js 库
this.script.load('filepicker', 'rangeSlider').then(data => {
console.log('script loaded ', data);
}).catch(error => console.log(error));