Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/angular/31.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/url/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在angular 2延迟加载模块中使用外部javascript库,而不是index.html_Angular_Angular Cli_External Js - Fatal编程技术网

在angular 2延迟加载模块中使用外部javascript库,而不是index.html

在angular 2延迟加载模块中使用外部javascript库,而不是index.html,angular,angular-cli,external-js,Angular,Angular Cli,External Js,所以我想在Angular 2应用程序中包含一个外部JS库,即is中的旋转滑块。我已经看过很多教程,展示了如何添加它。我已经成功地添加了它,但是引用了index.html上的库 正如您所知,无论应用程序是否访问需要旋转木马的组件,每次访问应用程序时都会加载库。因为它非常庞大,所以我只想在需要的地方加载它,这是在一个延迟加载的模块中 我还没有尝试过,但我确信我可以在使用它的组件中丢弃脚本标记,但我觉得这不对 一定有正确的方法。这是什么 谢谢 这实际上取决于您尝试加载的库的类型以及您在应用程序上使用的

所以我想在Angular 2应用程序中包含一个外部JS库,即is中的旋转滑块。我已经看过很多教程,展示了如何添加它。我已经成功地添加了它,但是引用了index.html上的库

正如您所知,无论应用程序是否访问需要旋转木马的组件,每次访问应用程序时都会加载库。因为它非常庞大,所以我只想在需要的地方加载它,这是在一个延迟加载的模块中

我还没有尝试过,但我确信我可以在使用它的组件中丢弃脚本标记,但我觉得这不对

一定有正确的方法。这是什么


谢谢

这实际上取决于您尝试加载的库的类型以及您在应用程序上使用的模块加载程序

我假设您使用的是Typescript或至少是ES6语法

如果您的第三方依赖项是AMD/UMD/CommonJS模块 在这种情况下,您可以在组件文件的顶部导入它

import {SomeClassName} from "path/to/library";
如果您的第三方是全局模块(例如:JQuery插件) 在这种情况下,您只需要导入js文件,它将在全局变量上可用

import "path/to/library";
结论 在任何情况下,您都应该检查第三方库是否已经有可用的打字,如果您正在使用Typescript,这将对您有所帮助

根据您的模块加载器,您可能需要在此之前进行一些配置。但是没有更多的信息是很难帮助你的

最好的,
jpsfs

我们正在我们的一个项目中这样做,以动态加载js库

 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' }
];
ScriptStore.ts将包含本地或远程服务器上脚本的路径和用于动态加载脚本的名称

 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));

如果我们在一个组件中使用最后一条导入语句,那么它可能只对该组件可用吗?就像我必须按顺序使用jquery、chart.js和mymake.js文件一样,我可以这样使用它:
import“path/to/jquery”;导入“path/to/chart.js”;导入“path/to/mymake.js”
?@AnkurShah no。使用最后一条导入语句,它将全局加载文件。