如何使用innerHTML在角度2中附加HTML内容

Man*_*ush 9 innerhtml angular2-template angular

我使用innerHTML在我的组件中呈现HTML内容.但是innerHTML删除HTML内容中的所有属性(例如:删除样式属性)并呈现它.但需要按原样呈现,并且不希望从HTML内容中提取任何属性.是否有任何与innerHTML等效的内容,或者我们是否可以使用innerHTML完成所需的结果.提前致谢.

我的模板文件

<div id="more-info-box" class="modal fade" role="dialog">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal">&times;</button>
                <h4 class="modal-title">Title</h4>
            </div>
            <div class="modal-body">
                <div class="clearfix">
                    <div [innerHTML]="htmlContent" class="long-desc-wrap">
                    </div>
                </div>
            </div>
         </div>
    </div>
</div><!-- End Info box -->
Run Code Online (Sandbox Code Playgroud)

我的组件文件

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


@Component({
  selector: 'cr-template-content',
  templateUrl: './app/channel.component.html'
})
export class TemplateComponent {
  constructor() {

  }

  htmlContent = '<p>This is my <strong style="color:red">Paragraph</strong></p>'

}
Run Code Online (Sandbox Code Playgroud)

我当前的输出是没有样式属性的内容.但是期望的结果应该是style属性.

Roh*_*ing 11

你可以直接注入你的组件html.

Plunker链接:

https://plnkr.co/edit/lWR6q8?p=preview

@Component({
  selector: 'my-app',
  template: `
    <div>
      <h2 [innerHTML]="htmlContent"></h2>
    </div>
  `,
})
export class App {
  htmlContent:string;
  constructor() {
    this.htmlContent = `<p>This is my html coontent</p>`
  }
}
Run Code Online (Sandbox Code Playgroud)


not*_*hon 6

使用ViewChild。

import {ViewChild,ElementRef,Component} from '@angular/core'
Run Code Online (Sandbox Code Playgroud)

在模板中创建局部变量

<div #div ></div>
Run Code Online (Sandbox Code Playgroud)

查询组件类中的局部变量

@Component({...}) class MyComponent {
@ViewChild('div') div:ElementRef;
}
Run Code Online (Sandbox Code Playgroud)

访问任何函数内的本机元素

this.div.nativeElement.innerHTML ="something";
Run Code Online (Sandbox Code Playgroud)

而已。?