Angular页面渲染或生命周期问题:当重新进入页面时,SVGGraphicsElement.getScreenCTM返回错误的平移值。
创始人
2024-10-30 11:30:33
0

问题描述: 当重新进入Angular页面时,使用SVGGraphicsElement.getScreenCTM方法获取SVG元素的平移值时,返回错误的值。

解决方法:

  1. 在Angular组件中,使用ngAfterViewInit生命周期钩子来处理SVG元素的渲染和获取平移值的逻辑。
import { Component, AfterViewInit, ViewChild, ElementRef } from '@angular/core';

@Component({
  selector: 'app-svg-component',
  template: `
    
      
    
  `,
})
export class SvgComponent implements AfterViewInit {
  @ViewChild('svgElement') svgElementRef: ElementRef;

  ngAfterViewInit(): void {
    this.getSVGElementTranslation();
  }

  getSVGElementTranslation(): void {
    const svgElement = this.svgElementRef.nativeElement;
    const gElement = svgElement.querySelector('g'); // Assuming the SVG element is inside a  element

    if (gElement) {
      const ctm = gElement.getScreenCTM();
      const translationX = ctm.e;
      const translationY = ctm.f;

      console.log('Translation X:', translationX);
      console.log('Translation Y:', translationY);
    }
  }
}
  1. 使用ngAfterViewChecked生命周期钩子来处理SVG元素的渲染和获取平移值的逻辑。
import { Component, AfterViewChecked, ViewChild, ElementRef } from '@angular/core';

@Component({
  selector: 'app-svg-component',
  template: `
    
      
    
  `,
})
export class SvgComponent implements AfterViewChecked {
  @ViewChild('svgElement') svgElementRef: ElementRef;

  ngAfterViewChecked(): void {
    this.getSVGElementTranslation();
  }

  getSVGElementTranslation(): void {
    const svgElement = this.svgElementRef.nativeElement;
    const gElement = svgElement.querySelector('g'); // Assuming the SVG element is inside a  element

    if (gElement) {
      const ctm = gElement.getScreenCTM();
      const translationX = ctm.e;
      const translationY = ctm.f;

      console.log('Translation X:', translationX);
      console.log('Translation Y:', translationY);
    }
  }
}

这两种方法都会在Angular组件初始化完成后,或在Angular渲染周期内检查并获取SVG元素的平移值。根据需要选择适合的生命周期钩子函数。

相关内容

热门资讯

分享透视!拱趴大菠萝挂怎么安装... 分享透视!拱趴大菠萝挂怎么安装,微乐小程序辅助器,妙招教程(有挂讲解)-哔哩哔哩1、起透看视 拱趴大...
揭露透视!wepoker国外版... 揭露透视!wepoker国外版透视,微乐陕西小程序破解器下载,策略教程(有挂实锤)-哔哩哔哩1、实时...
分享透视!菠萝德州透视脚本,微... 分享透视!菠萝德州透视脚本,微乐小程序黑科技辅助工具推荐,方案教程(有挂教程)-哔哩哔哩1、菠萝德州...
辅助透视!大菠萝789辅助器下... 辅助透视!大菠萝789辅助器下载,微乐江苏自建房辅助app,演示教程(有挂讲解)-哔哩哔哩一、大菠萝...
解谜透视!fishpoker透... 解谜透视!fishpoker透视,微信小程序修改器,教程书教程(有挂方略)-哔哩哔哩1.fishpo...
解迷透视!wepoker科技辅... 解迷透视!wepoker科技辅助器,微乐麻辣自建房辅助视频,妙招教程(详细教程)-哔哩哔哩1、这是跨...
关于透视!wepoker作弊方... 关于透视!wepoker作弊方法,微乐房间辅助工具在哪下载,绝活教程(揭秘有挂)-哔哩哔哩所有人都在...
教你透视!拱趴大菠萝有挂吗,微... 教你透视!拱趴大菠萝有挂吗,微信小程序有挂吗辅助,手筋教程(有挂详情)-哔哩哔哩1、拱趴大菠萝有挂吗...
教你透视!wepoker到底有... 教你透视!wepoker到底有没有透视,微乐自建房脚本下载,机巧教程(有挂解惑)-哔哩哔哩1、进入游...
解谜透视!hhpoker有透视... 解谜透视!hhpoker有透视功能吗,微乐广西小程序开发,资料教程(有挂详细)-哔哩哔哩1、hhpo...