Angular 2-对SVG进行消毒转换 [英] Angular 2 - Sanitizing transform on SVG

查看:120
本文介绍了Angular 2-对SVG进行消毒转换的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在mousemove上,我想更改SVG元素的翻译,但是已应用mot,并且收到以下警告: 警告:清理不安全的样式值" 我怎样才能应用这种风格?

On mousemove I want to change the translate of my SVG Element, however that is mot applied and I get the following warning: "WARNING: sanitizing unsafe style value" How can I get this style to be applied?

my-component.js:

my-component.js:

import {Component} from 'angular2/core';

@Component({
    selector: 'my-component',
    templateUrl: 'my-component.html'
})

export class MyComponent{
@HostListener('document:mousemove', ['$event'])
  onMouseMove(ev:MouseEvent) {

  this.mouseX = ev.clientX;
  this.mouseY = ev.clientY;

  for( var i = 0; i < this.lines.length - 1; i++ )
  {
    var weight = this.lines[i].weight;

    var translateX = Math.round( ( ( this.mouseX - this.halfWidth ) * weight ) / 7 );
    var translateY = Math.round( ( ( this.mouseY - this.halfHeight ) * weight ) / 7 );

    this.lines[i].translateX = translateX;
    this.lines[i].translateY = translateY;
   }
  }


  lines: [
    { translateX: 0.0, translateY: 0.0, weight: 0.40, x1: 86.69, y1: 1, x2: 98.91, y2: 1 },
    { translateX: 0.0, translateY: 0.0, weight: 0.40, x1: 85.31, y1: 9.67, x2: 98.23, y2: 9.67 }
  ]
}

my-component-html:

my-component-html:

<svg id="lines" viewBox="0 0 320.6 542.59">
  <line *ngFor="let line of lines" [attr.style]="{'transform': 'translate('+line.translateX+'px, ' + line.translateY+'px)'}" class="line" [attr.x1]="line.x1" [attr.y1]="line.y1" [attr.x2]="line.x2" [attr.y2]="line.y2"/>
</svg>

推荐答案

尝试使用DomSanitizer:

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

@Pipe({ name: 'safe' })
export class SafePipe implements PipeTransform {
    constructor(private sanitizer: DomSanitizer) {}
    transform(style) {
        return this.sanitizer.bypassSecurityTrustStyle(style);
    }
}

您的html可能看起来像这样:

your html might look like this:

[style.transform]="'translate('+line.translateX+'px, ' + line.translateY+'px)' | safe"

我不知道您要做什么,但这是 Plunker示例

I don't know what you're trying to do but here is Plunker Example

也不要忘记将SafePipe添加到@NgModule元数据的declaration数组中

Also don't forget to add SafePipe to declaration array of @NgModule metadata

这篇关于Angular 2-对SVG进行消毒转换的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆