Angular - 如何从指令

时间:2018-01-25 20:21:51

标签: angular angular-directive

我正在尝试创建一个指令,通过添加以innerHTML符号开头的子串的链接来修改元素的@

这是我到目前为止所尝试的,

linkify.directive.ts

  constructor(private elementRef: ElementRef, private renderer: Renderer2) { 
      let elementText = this.elementRef.nativeElement.innerHTML;
      // elementText = '@user mentioned you';
      console.log(`Element Text: ${elementText}`);
      this.renderer.setProperty(this.elementRef.nativeElement, 'innerHTML', this.stylize(elementText));
  }

我正在使用它

<p linkify> Hey @user check this out! </p>

调试时我做了以下观察,

  • this.elementRef.nativeElement.innerHTML总是有一个空字符串。
  • this.renderer.setProperty(this.elementRef.nativeElement, 'innerHTML', 'something'); something附加到元素文本的开头而不是替换。

问题1:如何访问元素的innerHTML

问题2:如何从指令设置元素的innerHTML?

Stackblitz demonstrating the problem

我尝试了Renderer2的文档,但对我没用。

1 个答案:

答案 0 :(得分:1)

正如@ bryan60建议的那样,理想的方法是创建一个管道而不是指令。

这是我最终创建的管道,

<强> linkify.pipe.ts

import { Pipe, PipeTransform } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';

@Pipe({
  name: 'linkify'
})
export class LinkifyPipe implements PipeTransform {

  constructor(private _domSanitizer: DomSanitizer) {}

  transform(value: any, args?: any): any {
    return this._domSanitizer.bypassSecurityTrustHtml(this.stylize(value));
  }

  private stylize(text: string): string {
    let stylizedText: string = '';
    if (text && text.length > 0) {
      for (let t of text.split(" ")) {
        if (t.startsWith("@") && t.length>1)
          stylizedText += `<a href="#${t.substring(1)}">${t}</a> `;
        else
          stylizedText += t + " ";
      }
      return stylizedText;
    }
    else return text;
  }

}

用法:

<p [innerHTML]="sample | linkify"></p>

Demo Stackblitz