3

我有一个脚本,我只想在一个组件上运行。我已经设法在组件上添加脚本,但是发生了一些我不完全确定如何解决的事情。

  1. 如果我导航到组件,脚本会添加到 DOM,但不会触发。如果我刷新页面,它可以工作
  2. 如果我导航到另一个组件并返回,则会再次添加脚本,并且它可以继续构建

组件.ts

import { Component, OnInit } from '@angular/core';
import { Renderer2, Inject } from '@angular/core';
import { DOCUMENT } from '@angular/platform-browser';

@Component({
  selector: 'app-privacy',
  templateUrl: './privacy.component.html',
  styles: []
})
export class PrivacyComponent implements OnInit {

  constructor(private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {
    let s = this._renderer2.createElement('script');
    s.type = `text/javascript`;
    s.src = `../../assets/scripts/privacy.js`;

    this._renderer2.appendChild(this._document.body, s);
   }

  ngOnInit() {
  }

}
4

2 回答 2

1

您需要将onload(如果您需要支持 IE 确保也支持onreadystatechange)处理程序添加到您的脚本元素中,该处理程序可以在脚本完成加载时调用您想要执行的函数。

要删除 onNgDestroy 脚本,请createElement?在 Component 上保存一个引用,并在 Destroy 生命周期挂钩中删除它。

import { Component, OnInit, OnDestroy } from '@angular/core';
import { Renderer2, Inject } from '@angular/core';
import { DOCUMENT } from '@angular/platform-browser';

@Component({
  selector: 'app-privacy',
  templateUrl: './privacy.component.html',
  styles: []
})
export class PrivacyComponent implements OnInit, OnDestroy {
  private s: any;
  constructor(private _renderer2: Renderer2, @Inject(DOCUMENT) private _document) {
    this.s = this._renderer2.createElement('script');
    this.s.type = `text/javascript`;
    this.s.src = `../../assets/scripts/privacy.js`;
    this.s.onload = this.doneLoading;

    this._renderer2.appendChild(this._document.body, this.s);
  }

  doneLoading () {
    // do what you need to do
  }


  ngOnDestroy() {
    // this removes the script so it won't be added again when the component gets initialized again.
    this._renderer2.removeChild(this._document.body, this.s)
  }

  ngOnInit() {
  }

}
于 2019-03-20T15:28:12.297 回答
0

您运行此 js 文件的方法是错误的,您应该执行以下操作以干净的方式实现此目的:

  1. 将您的 js 文件添加到资产(例如 assets/js/privacy.js)
  2. 将文件添加到 .angular-cli.json 脚本
  3. 现在,如果您在组件中声明它们,您可以从 Angular 组件中调用您的 js 函数

角-cli.json

"scripts": [
  "assets/js/privacy.js"
]

组件.ts

import { Component, OnInit } from '@angular/core';

declare function myFunc(): any; // function from privacy.js 

@Component({
  selector: 'app-privacy',
  templateUrl: './privacy.component.html',
  styles: []
})
export class PrivacyComponent implements OnInit {

  constructor() {
   }

  ngOnInit() {
      myFunc(); // call it
  }

}
于 2019-03-20T14:52:44.360 回答