質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
SVG

SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

1796閲覧

react.js で g要素に変換を加えたい(transform属性を追加したい)

hgmogi

総合スコア0

SVG

SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/05/10 07:38

前提・実現したいこと

g要素にtransform属性(translate)を追加したい。

なんとなくしたいことのイメージ
const g_style = {
transform: "translateX(320)",
}

...

<g style={g_style}> ... </g>

発生している問題・エラーメッセージ

<g>タグにstyleが反映されない。
transform: scale(0.5)とかだと反映されます。

該当のソースコード

index.js

1import React from 'react'; 2import ReactDOM from 'react-dom'; 3import './index.css'; 4 5function rt(){ 6 7 const w = window.innerWidth; 8 const h = window.innerHeight; 9 10 const style = { 11 width: w, 12 height: h 13 }; 14 15 const g_style1 = { 16 transform: "scale(0.5)", 17 } 18 const g_style2 = { 19 transform: "translateX(320)", 20 } 21 22 const element = 23 <svg xmlns="http://www.w3.org/2000/svg" version="1.1" width={w} height={h}> 24 <g style = {g_style1}> 25 <g style = {g_style2}> 26 <path d="M 160 160 L 480 160" stroke="#202020" stroke-width="10"/> 27 <path d="M 160 240 L 480 240" stroke="#202020" stroke-width="10"/> 28 <path d="M 160 320 L 480 320" stroke="#202020" stroke-width="10"/> 29 <path d="M 160 400 L 480 400" stroke="#202020" stroke-width="10"/> 30 <path d="M 160 480 L 480 480" stroke="#202020" stroke-width="10"/> 31 <circle cx="0" cy="0" r="40" transform="translate(320,320) skewX(-15)"/> 32 <path d="M 357 320 L 357 80" stroke="#202020" stroke-width="10"/> 33 </g> 34 </g> 35 </svg>; 36 37 ReactDOM.render( 38 element, 39 document.getElementById("root") 40 ); 41} 42rt();

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

よく分かりませんが、styleではない方法で属性に代入するといけました。

const trans = "translate(320,0)";

...

<g transform = {trans}> ... </g>

この場合、320を変数に置き換えてもうまくいくようです。

投稿2020/05/10 08:16

hgmogi

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2020/05/10 08:47

<g>のtransformは、styleで指定するものではなく独立した属性です。
hgmogi

2020/05/10 15:03

ありがとうございます。属性はすべてstyleで指定するものであると勝手に勘違いしておりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問