回答編集履歴

1

解説

2018/03/06 14:30

投稿

yambejp
yambejp

スコア114843

test CHANGED
@@ -87,3 +87,119 @@
87
87
  </ul>
88
88
 
89
89
  ```
90
+
91
+
92
+
93
+ # 解説付きひとまとめ
94
+
95
+
96
+
97
+ ```javascript
98
+
99
+ <style>
100
+
101
+ .menu{
102
+
103
+ width:300px;
104
+
105
+ border:solid 1px red;
106
+
107
+ }
108
+
109
+ .smenu{
110
+
111
+ margin:0;
112
+
113
+ padding:0;
114
+
115
+ }
116
+
117
+ </style>
118
+
119
+ <script>
120
+
121
+ /* DOMツリーの構築を待って発火 */
122
+
123
+ window.addEventListener('DOMContentLoaded', function(e){
124
+
125
+ /* menuクラスのタグを全部つかむ */
126
+
127
+ var menu=document.querySelectorAll(".menu");
128
+
129
+ /* menuをぐるっと走査する */
130
+
131
+ for(var i=0;i<menu.length;i++){
132
+
133
+ var x=menu[i];
134
+
135
+ /* menuないにあるsmenuの表示を消す */
136
+
137
+ x.querySelector('.smenu').style.display="none";
138
+
139
+ /* menuにclickイベントを付加する */
140
+
141
+ x.addEventListener('click',function(e){
142
+
143
+ /* イベントeを受け取って対象となるtを指定 */
144
+
145
+ var t=e.target;
146
+
147
+ /* 対象t内にあるsmenuの現在の表示状態をdに保持 */
148
+
149
+ var d=t.querySelector('.smenu').style.display;
150
+
151
+ /* もしdが"none"だった場合は空に、そうでない場合は"none"に */
152
+
153
+ d=(d=="none"?"":"none");
154
+
155
+ /* 対象tのsmenuの表示を変更 */
156
+
157
+ t.querySelector('.smenu').style.display=d;
158
+
159
+ });
160
+
161
+ }
162
+
163
+ /*
164
+
165
+ このforループを代替するのがArray.prototype.forEach.call()構文
166
+
167
+ */
168
+
169
+ });
170
+
171
+ </script>
172
+
173
+ <ul>
174
+
175
+ <li class="menu">メニュー①
176
+
177
+ <ul class="smenu">
178
+
179
+ <li>メニュー1</li>
180
+
181
+ <li>メニュー2</li>
182
+
183
+ <li>メニュー3</li>
184
+
185
+ </ul>
186
+
187
+ </li>
188
+
189
+ <li class="menu">メニュー②
190
+
191
+ <ul class="smenu">
192
+
193
+ <li>メニュー4</li>
194
+
195
+ <li>メニュー5</li>
196
+
197
+ <li>メニュー6</li>
198
+
199
+ </ul>
200
+
201
+ </li>
202
+
203
+ </ul>
204
+
205
+ ```