teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

1

HTMLの部分が抜けていたので追加しました

2018/02/03 09:19

投稿

退会済みユーザー
answer CHANGED
@@ -1,4 +1,4 @@
1
- `id="none"`を消すのではなく、`id="block"`を`<symbol>`として定義してあげて、`id="block"`を`<use>`で呼ぶのはいかがでしょうか。`<symbol id="svg">`の中でも`<use>`で参照できますので、定義は1回で済みます。
1
+ `id="none"`を消すのではなく、`id="block"`を`<symbol>`として定義してあげて、`id="block"`を`<use>`で呼ぶのはいかがでしょうか。`<use>` にidなりclassなりをつければ、スタイルを期待通りに適用できるはずです。`<symbol id="svg">`の中でも`<use>`で参照できますので、定義は1回で済みます。
2
2
 
3
3
  ```html
4
4
  <svg style="display:none">
@@ -15,7 +15,51 @@
15
15
  </symbol>
16
16
  </defs>
17
17
  </svg>
18
+ <div class="a">
19
+ <svg class="a1" viewBox="0 0 10 10">
20
+ <use xlink:href="#svg" x="0" y="0"/>
21
+ </svg>
22
+ <svg class="a2" viewBox="0 0 10 10">
23
+ <use xlink:href="#block" x="0" y="0"/>
24
+ </svg>
25
+ <svg class="a3" viewBox="0 0 20 20">
26
+ <use xlink:href="#block" x="0" y="0"/>
27
+ </svg>
28
+ <svg class="a4" viewBox="0 0 30 30">
29
+ <use class="a4-1" xlink:href="#block" x="10" y="10"/>
30
+ <use class="a4-2" xlink:href="#block" x="0" y="10"/>
31
+ <use class="a4-3" xlink:href="#block" x="0" y="0"/>
32
+ </svg>
33
+ </div>
18
34
  ```
19
35
 
36
+ で、たとえば以下のCSSにすると、
37
+
38
+ ```css
39
+ .a1 {
40
+ fill: red;
41
+ }
42
+ .a2 {
43
+ fill: blue;
44
+ }
45
+ .a3 {
46
+ fill: green;
47
+ }
48
+ .a4 {
49
+ fill: purple;
50
+ }
51
+ .a4-2 {
52
+ fill: gold;
53
+ }
54
+ .a4-3 {
55
+ fill: gray;
56
+ }
57
+ ```
58
+
59
+ こうなります。
60
+
61
+ ![イメージ説明](7b6965ab12f4ce089088f3ec2efdb7e0.png)
62
+
20
63
  以下で動作確認できます。大きさについては`viewBox`と`x`と`y`の指定で解決するのではないかと思います。
21
- [https://codepen.io/anon/pen/JpGwZG](https://codepen.io/anon/pen/JpGwZG)
64
+ [https://codepen.io/anon/pen/JpGwZG](https://codepen.io/anon/pen/JpGwZG)
65
+ Firefox(Win/Mac)、Chrome(Win/Mac)、Safari(Mac)、IE11(Win)、Edge(Win)では、大丈夫でした。