首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >访问innerText内部组件

访问innerText内部组件
EN

Stack Overflow用户
提问于 2020-03-02 03:24:27
回答 1查看 34关注 0票数 0

我有一个非常简单的组件,看起来像这样,基本上可以完成工作。

代码语言:javascript
复制
import { Component, Input } from '@angular/core';

@Component({
  selector: 'app-code',
  template: ' <pre><code [highlight]="code" [languages]="languages" [lineNumbers]="true"></code></pre> '
})
export class CodeComponent {

  readonly languages = ['java'];

  @Input()
  code = '';

  constructor() {
  }
}

但是,我想对它做一些小改动。

代码语言:javascript
复制
@Component({
  selector: 'app-code',
  template: '<pre><code [highlight]="code" [languages]="languages" [lineNumbers]="true"></code></pre>'
})
export class CodeComponent {

  readonly languages = ['java'];

  code = '';

  constructor(private elem: ElementRef) {
     this.code = elem.nativeElement.innerText;
  }
}

因此,与其写

<app-code [code]="'some code goes here'"></app-code>

我会写

<app-code>some code goes here</app-code>

不幸的是,它不工作,我的代码块仍然是空的

EN

回答 1

Stack Overflow用户

发布于 2020-03-02 04:04:44

无法获取innerText,因为未绘制CodeComponent

您需要使用ngAfterViewInit

代码语言:javascript
复制
@Component({
  selector: 'app-code',
  template: '<pre><code [highlight]="code" [languages]="languages" [lineNumbers]="true"></code></pre>'
})
export class CodeComponent {

  readonly languages = ['java'];

  code = '';

  constructor(private elem: ElementRef) {
  }

  ngAfterViewInit() {
    this.code = elem.nativeElement.innerText;
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60478890

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档