質問編集履歴

4

追記

2021/11/10 02:43

投稿

MK-95
MK-95

スコア0

test CHANGED
File without changes
test CHANGED
@@ -36,61 +36,69 @@
36
36
 
37
37
  <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.2/css/all.css" integrity="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr" crossorigin="anonymous">
38
38
 
39
- <!-- 音声ファイル -->
40
-
41
- <audio id="bgm1" preload>
42
-
43
- <source src="●●●●" type="audio/mp3">
44
-
45
- </audio>
46
-
47
- <!-- 再生ボタン -->
48
-
49
- <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
50
-
51
- <audio id="bgm1" preload>
52
-
53
- <source src="●●●●" type="audio/mp3">
54
-
55
- </audio>
56
-
57
- <!-- 再生ボタン -->
58
-
59
- <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
60
-
61
- <audio id="bgm1" preload>
62
-
63
- <source src="●●●●" type="audio/mp3">
64
-
65
- </audio>
66
-
67
- <!-- 再生ボタン -->
68
-
69
- <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
70
-
71
- <audio id="bgm1" preload>
72
-
73
- <source src="●●●●" type="audio/mp3">
74
-
75
- </audio>
76
-
77
- <!-- 再生ボタン -->
78
-
79
- <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
80
-
81
- <audio id="bgm1" preload>
82
-
83
- <source src="●●●●" type="audio/mp3">
84
-
85
- </audio>
86
-
87
- <!-- 再生ボタン -->
88
-
89
- <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
90
-
91
- <audio id="bgm1" preload>
92
-
93
- <source src="●●●●" type="audio/mp3">
39
+
40
+
41
+ <!-- 音声ファイル -->
42
+
43
+ <audio id="bgm1">
44
+
45
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
46
+
47
+ </audio>
48
+
49
+ <!-- 再生ボタン -->
50
+
51
+ <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
52
+
53
+
54
+
55
+ <!-- 音声ファイル -->
56
+
57
+ <audio id="bgm1">
58
+
59
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
60
+
61
+ </audio>
62
+
63
+ <!-- 再生ボタン -->
64
+
65
+ <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
66
+
67
+
68
+
69
+ <!-- 音声ファイル -->
70
+
71
+ <audio id="bgm1">
72
+
73
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
74
+
75
+ </audio>
76
+
77
+ <!-- 再生ボタン -->
78
+
79
+ <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
80
+
81
+
82
+
83
+ <!-- 音声ファイル -->
84
+
85
+ <audio id="bgm1">
86
+
87
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
88
+
89
+ </audio>
90
+
91
+ <!-- 再生ボタン -->
92
+
93
+ <button id="btn-play" type="button"><i class="fas fa-play"></i></button>
94
+
95
+
96
+
97
+ <!-- 音声ファイル -->
98
+
99
+ <audio id="bgm1">
100
+
101
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
94
102
 
95
103
  </audio>
96
104
 
@@ -167,3 +175,171 @@
167
175
  </script>
168
176
 
169
177
  ```
178
+
179
+
180
+
181
+ ### 追記
182
+
183
+
184
+
185
+ id要素をclassに書き換えましたが当初の現象と変わりませんでした。
186
+
187
+
188
+
189
+ ```HTML
190
+
191
+ <!DOCTYPE html>
192
+
193
+ <html>
194
+
195
+ <head>
196
+
197
+ <meta charset="UTF-8">
198
+
199
+ <title>HTML5 Audio Sample1</title>
200
+
201
+ </head>
202
+
203
+ <body>
204
+
205
+ <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.2/css/all.css" integrity="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr" crossorigin="anonymous">
206
+
207
+
208
+
209
+ <!-- 音声ファイル -->
210
+
211
+ <audio class="bgm1">
212
+
213
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
214
+
215
+ </audio>
216
+
217
+ <!-- 再生ボタン -->
218
+
219
+ <button class="btn-play" type="button"><i class="fas fa-play"></i></button>
220
+
221
+
222
+
223
+ <!-- 音声ファイル -->
224
+
225
+ <audio class="bgm1">
226
+
227
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
228
+
229
+ </audio>
230
+
231
+ <!-- 再生ボタン -->
232
+
233
+ <button class="btn-play" type="button"><i class="fas fa-play"></i></button>
234
+
235
+
236
+
237
+ <!-- 音声ファイル -->
238
+
239
+ <audio class="bgm1">
240
+
241
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
242
+
243
+ </audio>
244
+
245
+ <!-- 再生ボタン -->
246
+
247
+ <button class="btn-play" type="button"><i class="fas fa-play"></i></button>
248
+
249
+
250
+
251
+ <!-- 音声ファイル -->
252
+
253
+ <audio class="bgm1">
254
+
255
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
256
+
257
+ </audio>
258
+
259
+ <!-- 再生ボタン -->
260
+
261
+ <button class="btn-play" type="button"><i class="fas fa-play"></i></button>
262
+
263
+
264
+
265
+ <!-- 音声ファイル -->
266
+
267
+ <audio class="bgm1">
268
+
269
+ <source src="https://miku3.net/asset/sound/html5/op.mp3" type="audio/mp3">
270
+
271
+ </audio>
272
+
273
+ <!-- 再生ボタン -->
274
+
275
+ <button class="btn-play" type="button"><i class="fas fa-play"></i></button>
276
+
277
+ </body>
278
+
279
+ </html>
280
+
281
+ ```
282
+
283
+
284
+
285
+ ```JavaScript
286
+
287
+ <script>
288
+
289
+ for(var i=0;i<audios.length;i++){
290
+
291
+ audios[ i ].addEventListener( "play", function(){
292
+
293
+ for(var j=0;j<audios.length;j++){
294
+
295
+ if( audios[ j ]!=this ){ audios[ j ].pause() }
296
+
297
+ }
298
+
299
+ }, false );
300
+
301
+ }
302
+
303
+ const bgm1 = document.querySelector(".bgm1"); // <audio>
304
+
305
+ const btn = document.querySelector(".btn-play"); // <button>
306
+
307
+ btn.addEventListener("click", ()=>{
308
+
309
+ // pausedがtrue=>停止, false=>再生中
310
+
311
+ if( ! bgm1.paused ){
312
+
313
+ btn.innerHTML = '<i class="fas fa-play"></i>';
314
+
315
+ bgm1.pause();
316
+
317
+ }
318
+
319
+ else{
320
+
321
+ btn.innerHTML = '<i class="fas fa-pause"></i>';
322
+
323
+ bgm1.play();
324
+
325
+ }
326
+
327
+ });
328
+
329
+ /**
330
+
331
+ * [event] 再生終了時に実行
332
+
333
+ */
334
+
335
+ bgm1.addEventListener("ended", ()=>{
336
+
337
+ bgm1.currentTime = 0; // 再生位置を先頭に移動
338
+
339
+ btn.innerHTML = '<i class="fas fa-play"></i>'; // 「再生ボタン」に変更
340
+
341
+ });
342
+
343
+ </script>
344
+
345
+ ```

3

タイトル修正

2021/11/10 02:43

投稿

MK-95
MK-95

スコア0

test CHANGED
@@ -1 +1 @@
1
- 音声再生の処理が一度しか実行されない
1
+ 【JavaScript】音声再生の処理が一度しか実行されない
test CHANGED
File without changes

2

初心者マーク追加

2021/11/10 02:07

投稿

MK-95
MK-95

スコア0

test CHANGED
File without changes
test CHANGED
@@ -16,7 +16,7 @@
16
16
 
17
17
  コードは以下のようになっています。
18
18
 
19
-
19
+  
20
20
 
21
21
  ```HTML
22
22
 

1

文法の修正

2021/11/10 01:45

投稿

MK-95
MK-95

スコア0

test CHANGED
File without changes
test CHANGED
@@ -8,7 +8,7 @@
8
8
 
9
9
 
10
10
 
11
- 上記の記事を参考に音声再生ボタンを実装したいのですが、
11
+ 上記の記事を参考にJavaScriptでシンプルな音声再生ボタンを実装したいのですが、
12
12
 
13
13
  一つ目のボタンしか再生されず、二つ目以降のボタンはクリックしても一時停止に切り替わらず再生もされません。
14
14