Правильный способ Предоставить DomSanitizer компоненту с Angular 2 RC6
Я пытаюсь использовать DomSanitizer для очистки динамического URL-адреса в компоненте, используя не могу понять, как правильно указать поставщика для этой службы.
Я использую Angular 2.0.0-rc.6
Вот мой текущий компонент:
@Component({
templateUrl: './app.component.html',
styleUrls: [ './app.component.css' ],
providers: [ DomSanitizer ],
})
export class AppComponent implements OnInit
{
public url: SafeResourceUrl;
constructor(private sanitizer: DomSanitizer) {}
ngOnInit() {
let id = 'an-id-goes-here';
let url = `https://www.youtube.com/embed/${id}`;
this.videoUrl = this.sanitizer.bypassSecurityTrustResourceUrl(url);
}
ngOnDestroy() {}
}
Это приводит к ошибке this.sanitizer.bypassSecurityTrustResourceUrl is not a function
во время выполнения.
Может кто-нибудь показать мне пример того, как правильно предоставить провайдера для DomSanitizer? Спасибо!
5 ответов
Вам не нужно заявлять providers: [ DomSanitizer ]
больше
Просто надо import
DomSanitizer
как показано ниже,
import { DomSanitizer, SafeResourceUrl, SafeUrl} from '@angular/platform-browser';
в компоненте внедрить его через конструктор, как показано ниже,
constructor(private sanitizer: DomSanitizer) {}
Импортируйте эти
import { DomSanitizer, SafeResourceUrl, SafeUrl } from '@angular/platform-browser';
определить переменную
trustedDashboardUrl : SafeUrl;
Используйте это в конструкторе, как это-
constructor(
private sanitizer: DomSanitizer) {}
Конкретный URL, как это-
this.trustedDashboardUrl =
this.sanitizer.bypassSecurityTrustResourceUrl
("URL");
Посмотрите, поможет ли это.
Это проще, если вы можете добавить собственный канал для SanitizedHtmlPipe . потому что мы можем использовать глобально в угловом проекте:
- продезинфицированный-html.pipe.ts
import { Pipe, PipeTransform } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser'
@Pipe({
name: 'sanitizedHtml'
})
export class SanitizedHtmlPipe implements PipeTransform {
constructor(private sanitized: DomSanitizer) {}
transform(value: any): any {
return this.sanitized.bypassSecurityTrustHtml(value);
}
}
- hero.component.html
<div [innerHTML]="htmlString | sanitizedHtml"></div>
- hero.component.ts
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-hero',
templateUrl: './hero.component.html',
styleUrls: ['./hero.component.css']
})
export class HeroComponent implements OnInit {
htmlString: any;
constructor() { }
ngOnInit(): void {
this.htmlString = `
<div class="container">
<header class="blog-header py-3">
<div class="row flex-nowrap justify-content-between align-items-center">
<div class="col-4 pt-1">
<a class="text-muted" href="#">Subscribe</a>
</div>
<div class="col-4 text-center">
<a class="blog-header-logo text-dark" href="#">Large</a>
</div>
<div class="col-4 d-flex justify-content-end align-items-center">
<a class="text-muted" href="#">
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="mx-3"><circle cx="10.5" cy="10.5" r="7.5"></circle><line x1="21" y1="21" x2="15.8" y2="15.8"></line></svg>
</a>
<a class="btn btn-sm btn-outline-secondary" href="#">Sign up</a>
</div>
</div>
</header>
</div>`;
}
}
Для получения дополнительной информации вы можете посетить эту ссылку
Оба должны работать
constructor(private sanitizer: DomSanitizer) {}
constructor(private sanitizer: Sanitizer) {}
Инъекционное DomSanitizer
лучше, потому что только этот тип обеспечивает необходимые методы без приведения.
Убедитесь, что вы импортировали BrowserModule
@NgModule({
imports: [BrowserModule],
})
См. Также В RC.1 некоторые стили не могут быть добавлены с использованием синтаксиса привязки.
Чтобы включить это изменение в ionic, вы должны добавитьIonicSafeString