在Angular 8中动态添加div的一种解决方法是使用组件的ViewChild和Renderer2。
首先,在组件的HTML模板中,添加一个容器元素来动态地添加div:
然后,在组件的类中,使用ViewChild装饰器和ElementRef来获取容器元素的引用,并使用Renderer2来动态添加div:
import { Component, ViewChild, ElementRef, Renderer2 } from '@angular/core';
@Component({
selector: 'app-my-component',
templateUrl: './my-component.component.html',
styleUrls: ['./my-component.component.css']
})
export class MyComponent {
@ViewChild('container', { static: true }) container: ElementRef;
constructor(private renderer: Renderer2) {}
addDiv() {
const div = this.renderer.createElement('div');
const text = this.renderer.createText('Dynamic div');
this.renderer.appendChild(div, text);
this.renderer.appendChild(this.container.nativeElement, div);
}
}
在上述代码中,addDiv()方法会在点击某个按钮或者其他事件触发时被调用,用于动态添加一个div元素。首先,使用Renderer2的createElement()方法创建一个div元素,并使用createText()方法创建文本节点。然后,使用appendChild()方法将文本节点添加到div元素中,再将div元素添加到容器元素中。
最后,在组件的模板中添加一个按钮或者其他事件来调用addDiv()方法:
当点击按钮时,会动态地在容器元素中添加一个div元素。
请注意,上述代码示例中使用了ViewChild装饰器的静态选项,这是因为在Angular 8中,装饰器的默认选项已经改为静态。如果你正在使用Angular 9或更高版本,请将{ static: true }选项删除。