回答編集履歴

1

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

2018/02/03 09:19

投稿

退会済みユーザー
test 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
 
4
4
 
@@ -32,10 +32,98 @@
32
32
 
33
33
  </svg>
34
34
 
35
+ <div class="a">
36
+
37
+ <svg class="a1" viewBox="0 0 10 10">
38
+
39
+ <use xlink:href="#svg" x="0" y="0"/>
40
+
41
+ </svg>
42
+
43
+ <svg class="a2" viewBox="0 0 10 10">
44
+
45
+ <use xlink:href="#block" x="0" y="0"/>
46
+
47
+ </svg>
48
+
49
+ <svg class="a3" viewBox="0 0 20 20">
50
+
51
+ <use xlink:href="#block" x="0" y="0"/>
52
+
53
+ </svg>
54
+
55
+ <svg class="a4" viewBox="0 0 30 30">
56
+
57
+ <use class="a4-1" xlink:href="#block" x="10" y="10"/>
58
+
59
+ <use class="a4-2" xlink:href="#block" x="0" y="10"/>
60
+
61
+ <use class="a4-3" xlink:href="#block" x="0" y="0"/>
62
+
63
+ </svg>
64
+
65
+ </div>
66
+
35
67
  ```
68
+
69
+
70
+
71
+ で、たとえば以下のCSSにすると、
72
+
73
+
74
+
75
+ ```css
76
+
77
+ .a1 {
78
+
79
+ fill: red;
80
+
81
+ }
82
+
83
+ .a2 {
84
+
85
+ fill: blue;
86
+
87
+ }
88
+
89
+ .a3 {
90
+
91
+ fill: green;
92
+
93
+ }
94
+
95
+ .a4 {
96
+
97
+ fill: purple;
98
+
99
+ }
100
+
101
+ .a4-2 {
102
+
103
+ fill: gold;
104
+
105
+ }
106
+
107
+ .a4-3 {
108
+
109
+ fill: gray;
110
+
111
+ }
112
+
113
+ ```
114
+
115
+
116
+
117
+ こうなります。
118
+
119
+
120
+
121
+ ![イメージ説明](7b6965ab12f4ce089088f3ec2efdb7e0.png)
36
122
 
37
123
 
38
124
 
39
125
  以下で動作確認できます。大きさについては`viewBox`と`x`と`y`の指定で解決するのではないかと思います。
40
126
 
41
127
  [https://codepen.io/anon/pen/JpGwZG](https://codepen.io/anon/pen/JpGwZG)
128
+
129
+ Firefox(Win/Mac)、Chrome(Win/Mac)、Safari(Mac)、IE11(Win)、Edge(Win)では、大丈夫でした。