Angular 4中显示CSS样式
这次给大家带来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='font-size:30px'>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 样式。
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
以上就是Angular 4中显示CSS样式的详细内容,更多请关注其它相关文章!
上一篇: python网页请求urllib2模块简单封装代码
下一篇: php中定时计划任务的实现原理_PHP
推荐阅读
-
idea下maven项目,样式css、js更新后,页面不显示更新内容
-
Angular 4中如何显示内容的CSS样式示例代码
-
CSS样式 解决文字过长显示省略号问题
-
解决了部署到Heroku时无法显示bootstrap CSS样式的问题
-
给HTML页面添加CSS样式和自适应布局控制其显示
-
CodeIgniter css样式不显示有关问题
-
css 在不同媒介的显示样式控制
-
element UI设置dialog在视图居中显示,css设置dialog样式
-
* 打开慢或样式(CSS)无法正常显示问题_html/css_WEB-ITnose
-
CSS3 :nth-child()伪类选择器实现奇偶行显示不同样式