У меня есть сайт на Angular / Typescript. Мне нужно встроить сторонний скрипт. Скрипт генерирует таблицу.
Как я могу отобразить эту таблицу внутри home.component. html. Не в начале или в начале, а внутри. Вот так.
Мне удалось встроить скрипт, но похоже, что скрипт не выполняет рендеринг, поэтому он просто отображает его в исходном коде, но не отображает таблицу.
Обновление
Таблица теперь может отображаться, но только за пределами app- root. Он должен находиться внутри home.component. html. Исходное изображение
home.component.ts
import { Component, OnInit, AfterViewInit } from '@angular/core';
import { DOCUMENT } from '@angular/common'
declare var myExtObject: any;
@Component({
selector: 'app-careers',
templateUrl: './careers.component.html',
styleUrls: ['./careers.component.scss']
})
export class CareersComponent implements OnInit {
private iife: any
ngOnInit() {
}
ngAfterViewInit() {
this.iife = myExtObject()
}
}
домашний. Компонент. html
<div id="BambooHR">
<script src="https://xxxxxxx.xxx.com" type="text/javascript"></script>
<div></div>
</div>
Код сценария приведен ниже. У меня это во внешнем. js файле.
var myExtObject = function() {
//add css file to dom so IE8 recognizes it
document.write('<link href="https://xxx.css" rel="stylesheet" />');
var divId="BambooHR-ATS";
var el=document.getElementById(divId);
if(!el) {
document.write("<div id=\""+divId+"\"></div>");
}
var xmlhttp;
var ieFlag = 0;
if (('XDomainRequest' in window && window.XDomainRequest !== null) && document.documentMode < 10) {
xmlhttp=new XDomainRequest();
ieFlag = 1;
} else if (window.XMLHttpRequest) {
xmlhttp=new XMLHttpRequest();
} else {
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
var embedUrl = "https://xxx.php";
var departmentId = "0";
if (departmentId) {
embedUrl += '?departmentId=' + encodeURIComponent(departmentId);
}
document.addEventListener('readystatechange', function(event) {
if (event.target.readyState === "complete") {
if (ieFlag == 1) { //needed for IE9 CORS
xmlhttp.onload = loadd;
xmlhttp.open("GET",embedUrl);
xmlhttp.send();
} else {
xmlhttp.onreadystatechange=function() {
if(xmlhttp.readyState==4 && xmlhttp.status==200) {
var content = xmlhttp.responseText;
var footerId="BambooHR-Footer";
var fel=document.getElementById(footerId);
el=document.getElementById(divId);
if(el && !fel) {
content += "<div id="xxx"/></a></div>";
}
if(el) el.innerHTML=content;
}
}
xmlhttp.open("GET",embedUrl,true);
xmlhttp.send();
}
}
});
function loadd() { //needed for IE9 CORS
var content = xmlhttp.responseText;
var footerId="BambooHR-Footer";
var fel=document.getElementById(footerId);
el=document.getElementById(divId);
if(el && !fel) {
content += "<div id=\"BambooHR-Footer\">Powered by <a href=\"http://www.bamboohr.com\" target=\"_blank\" rel=\"external\"><img src=\"https://resources.bamboohr.com/images/footer-logo.png\" alt=\"BambooHR - HR software\"/></a></div>";
}
el.innerHTML=content;
}
};