首頁  >  文章  >  web前端  >  Angular 4中顯示CSS樣式

Angular 4中顯示CSS樣式

php中世界最好的语言
php中世界最好的语言原創
2018-04-16 09:22:181892瀏覽

這次帶給大家Angular 4中顯示CSS樣式,Angular 4中顯示CSS樣式的注意事項有哪些,下面就是實戰案例,一起來看一下。

在開始本文的正文之前,我們先來看看angular2中將帶標籤的文字輸出在頁面上的相關內容,為了系統性的防範XSS問題,Angular預設把所有值都當做不可信任的。 當值從範本中以屬性(Property)、DOM元素屬性(Attribte)、CSS類別綁定或插值表達式等路徑插入DOM中的時候, Angular將對這些值進行無害化處理(Sanitize),對不可信的值進行編碼。

h3>Binding innerHTML</h3>
<p>Bound value:</p>
<p
class="e2e-inner-html-interpolated">{{htmlSnippet}}</p>
<p>Result of binding to innerHTML:</p>
<p
class="e2e-inner-html-bound" [innerHTML]="htmlSnippet"></p>
[innerHTML]="htmlSnippet"

這個屬性可以辨識 HTML標籤 但不辨識標籤中的屬性值

發現問題

大家都知道Angular 中有 innerHTML 屬性來設定要顯示的內容,但如果內容包含 CSS 樣式,無法顯示樣式的效果。

例如:

public content: string = "<p style=&#39;font-size:30px&#39;>Hello Angular</p>";
<p [innerHTML]="content"></p>

只會顯示 Hello World ,字體不會是 30px,也就是 CSS 樣式沒有效果。

解決方案

自訂一個 Pipe 來轉換內容。看下面程式碼。

寫一個 HtmlPipe 類別

import {Pipe, PipeTransform} from "@angular/core";
import {DomSanitizer} from "@angular/platform-browser";
@Pipe({
 name: "html"
})
export class HtmlPipe implements PipeTransform{
 constructor (private sanitizer: DomSanitizer) {
 }
 transform(style) {
 return this.sanitizer.bypassSecurityTrustHtml(style);
 }
}

# 在需要的模組裡面引入管道 HtmlPipe

@NgModule({
 declarations: [
 HtmlPipe
 ]
})

在 innerHtml 中增加管道名稱

<p [innerHTML]="content | html"></p>

這樣就可以顯示 content 的 CSS 樣式。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:



#

以上是Angular 4中顯示CSS樣式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn