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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

5303閲覧

複数のaudioタグ利用時に常に1つだけ再生するようにしたい

8yazaki

総合スコア454

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

1グッド

1クリップ

投稿2018/09/13 07:10

編集2018/09/13 08:04

状態と変更予定内容

audioタグを使用して複数の音楽をサイト上に掲載し再生できるようにしているのですが、曲Aを再生中に曲Bの再生ボタンを押すと曲Aと曲Bが同時に再生されてしまいます。

曲Aを再生中に曲Bの再生ボタンを押した際に、曲Aを停止して曲Bのみを再生できるようにしたいと考えています。

質問内容

上記の様な事を実装できるJavaScriptのライブラリ等がある場合教えてください。
(探して見たのですが1つの曲を制御する方法しか見つかりませんでした)

もしくは、ライブラリを使用しなくても実装が可能でしたらアドバイスを頂けると幸いです。

ソース

実際のサイト
https://www.8yazaki.jp/
※公開している曲はすべてオリジナル曲です

サイトのソース
https://github.com/8yazaki/official-site

補足情報

曲情報や音源・画像はXMLファイルにまとめ、jQueryを使って流し込んで表示させています。
(このあたりもJavaScriptを実装するときの弊害になりそうですが・・・)


アドバイス頂けると幸いです。

_lemon2003_👍を押しています

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

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

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

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

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

_lemon2003_

2018/09/13 08:23

曲Aを再生中に曲Bを再生したら、曲Aを止めるということですか?
8yazaki

2018/09/13 08:49

はい。そうです。 説明が下手ですみません^^;
guest

回答1

0

ベストアンサー

javascript

1(function(){ 2 let playingAudio = null; 3 let audioList = document.querySelectorAll("div.audio > audio"); 4 5 let playAudioHandler = function playingAudioHandler(event){ 6 if(playingAudio && playingAudio !== event.target){ 7 playingAudio.pause(); 8 // 停止時に位置を最初にする場合は下↓のコメントを外す 9 // playingAudio.currentTime = 0; 10 } 11 playingAudio = event.target; 12 } 13 14 for(let i = 0, l = audioList.length; i < l; i++){ 15 audioList[i].addEventListener("play", playAudioHandler); 16 } 17})();

追記1

html

1 <!-- 曲リスト全体 --> 2 <script> 3 $(function() { 4 $.ajax({ 5 url: 'musics.xml?20180808', 6 type: 'GET', 7 dataType: 'xml', 8 timeout: 1000, 9 error: function() { 10 console.log("曲リストの読み込みに失敗しました"); 11 }, 12 success: function(xml) { 13 $(xml).find('music').each(function() { 14 $("#musics_list").append( 15 '<article class="music"><div><div class="type"><div>' + 16 $(this).find('type').text() + '</div></div><h4>「' + 17 $(this).find('title').text() + '」</h4><img src="img/jacket/' + 18 $(this).find('jacket').text() + '" alt="' + 19 $(this).find('title').text() + '"><span class="mask"><p>' + 20 $(this).find('comment').text() + '</p><a href="' + 21 $(this).find('mp3').text() + '" download="music/' + 22 $(this).find('mp3').text() + '">MP3ダウンロード</a></span><div class="audio"><audio src="music/' + 23 $(this).find('mp3').text() + '" controls="controls"></audio></div></div></article>' 24 25 ); 26 }); 27 28 $(xml).find('music:lt(1)').each(function() { 29 $("#new_songs").append( 30 '<li><img src="img/jacket/' + 31 $(this).find('jacket').text() + '" alt="' + 32 $(this).find('title').text() + '"><h4>「' + 33 $(this).find('title').text() + '」</h4><p>' + 34 $(this).find('comment').text() + '</p><a href="music/' + 35 $(this).find('mp3').text() + '" download="' + 36 $(this).find('mp3').text() + '">MP3ダウンロード</a><audio src="music/' + 37 $(this).find('mp3').text() + '" controls="controls"></audio></li>' 38 ); 39 }); 40 41 let $playingAudio = null; 42 let $audioList = $("div.audio>audio, ul#new_songs>li>audio"); 43 44 let playAudioHandler = function playAudioHandler(event){ 45 if($playingAudio && $playingAudio[0] !== event.target){ 46 $playingAudio[0].pause(); 47 48 // 停止時に位置を最初にする場合は下↓のコメントを外す 49 // playingAudio.currentTime[0] = 0; 50 } 51 $playingAudio = $(event.target); 52 } 53 54 for(let i = 0, l = $audioList.length; i < l; i++){ 55 $audioList[i].addEventListener("play", playAudioHandler); 56 } 57 } 58 }); 59 }); 60 </script>

動作しないため訂正版。
当該ページの34行目辺りの <!-- 曲リスト全体 --> から
115行目辺りの <!-- 常に1曲のみ再生の制御 ここまで --> までを
上記のコードに書き換えてください。

投稿2018/09/15 00:40

編集2018/09/15 12:47
_lemon2003_

総合スコア274

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

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

8yazaki

2018/09/15 04:09

具体的なコードありがとうございます! 教えていただいたコードを追加してみたのですがうまく動作しませんでした。 コードを追加したものは下記URLにてアップしておきました https://www.8yazaki.jp/test.html 私の追加の仕方が悪いのでしょうか?^^;
_lemon2003_

2018/09/15 12:48

追記しました。 これで動きますでしょうか?
8yazaki

2018/09/15 15:39

確認が遅くなりましたm(_ _)m ありがとうございます! 問題なく動きました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問