web-dev-qa-db-fra.com

Comment puis-je définir la valeur d'un élément natif dans Angular, en utilisant Renderer2?

Je voudrais définir le innerText/innerHTML/textContent d'un nativeElement?

this.render.setValue(this.nativeCloneLi.querySelector('.down .inn'), timeVal);

timeVal est une chaîne

l'élément est correctement sélectionné, mais setValue semble ne pas fonctionner du tout

10
Donovant

Vous devez utiliser renderer.setProperty() au lieu de renderer.setValue().

import { Component, Renderer2, AfterViewInit, ElementRef, ViewChild } from '@angular/core';

@Component({
  selector: 'my-app',
  template: `
  <div #el></div>
  `,
  styleUrls: [ './app.component.css' ]
})
export class AppComponent implements AfterViewInit {
  @ViewChild('el') el: ElementRef;

  constructor(private renderer: Renderer2) {}

  ngAfterViewInit() {
    this.renderer.setProperty(this.el.nativeElement, 'innerHTML', '<h1>Hello world</h1>');
  }
}

Démo en direct

20
Tomasz Kula