问题描述
我对Angular 8的样式清理有疑问。
我已经使用了ngStyle多次,但是这次我无法设置td
元素的边框。
我正在尝试根据字段设置边框样式。如果该字段对我来说具有相关的内容,那么我会忽略它,否则我不会。我不知道该字段的可能值的数目,也不知道确切的值:它是动态的,我只知道我感兴趣的值。
<ng-container matColumnDef="{{cam}}">
<th mat-header-cell *matHeaderCellDef class="header"> {{cam}} </th>
<td mat-cell *matCellDef="let piano" class="cellaMagazzino" [ngStyle]=" {'border':shouldHighlight(piano[cam])}">
<div>
<!--content-->
</div>
</td>
</ng-container>
我的打字稿功能看起来像这样:
shouldHighlight(element){
if (this.listaCommittenti == undefined && this.listaNumOrdine == undefined) {
let found = this.releventContentList.find(item => item.property == element.property)
let result = found != undefined ? '3px solid ' + this.myVariable["color"] : ""
return result
}
我其他时候使用了ngStyle调用函数,但是在这种情况下,我得到了错误:
警告:清理不安全的样式值3px固体rgb(241、196、15)(请参见http://g.co/ng/security#xss)。
是否需要某种配置?有解决方法吗?
解决方法
这对您有用吗?
打字稿:
getHighlightColor():string {
return "rgba(255,255,1)";
}
shouldHighlight(): boolean {
return true;
}
HTML:
<td mat-cell [style.border-color]="getHighlightColor(piano[cam])" [ngClass]="{ 'highlighted': shouldHighlight(piano[cam])}"
CSS:
.highlighted{
border-width:3px;
border-style:solid;
border-color:transparent;
}
,
通常,我强烈建议不要在模板中使用函数调用,因为它是真正的性能杀手。最好计算所需的类并将它们添加到您的数据中。
Federico的方法不错,但是您也可以使用原始方法并通过"browser": {
"original-fs": false
}
参见Trusting safe values