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

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

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

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

JavaScript

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

Q&A

解決済

2回答

1824閲覧

javascriptのfor文について

no23h

総合スコア49

for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

JavaScript

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

0グッド

0クリップ

投稿2017/05/11 08:13

下記参考サイトを元に、youtubeのチャンネルIDを指定して、チャンネル内の最新3つの動画をiframeで出力したいのですが、for文の記述方法がわからず困っています。

参考サイト

<script> $(function() { //step1:uploadsのplaylistIdの取得を試みる $.ajax( { "timeout": 5000, "url": "https://www.googleapis.com/youtube/v3/channels", "type": "GET", "dataType": "jsonp", "data": { "part": "contentDetails", "key": "APIキー", "id": "チャンネルID", }, "success": function(res) { if(!res || !res.items || !res.items[0] || !res.items[0].contentDetails || !res.items[0].contentDetails.relatedPlaylists || !res.items[0].contentDetails.relatedPlaylists.uploads) { //error処理 alert("error!"); return ""; } var playlistId = res.items[0].contentDetails.relatedPlaylists.uploads; //step2:uploadsのplaylistIdが動画リストを取得する $.ajax( { "timeout": 5000, "url": "https://www.googleapis.com/youtube/v3/playlistItems", "type": "GET", "dataType": "jsonp", "data": { "part": "snippet", "key": "APIキー", "playlistId": playlistId, "maxResults": 3 }, "success": function(res) { if(!res || !res.items || !res.items[0] || !res.items[0].snippet || !res.items[0].snippet.resourceId || !res.items[0].snippet.resourceId.videoId) { //error処理 alert("error!"); return ""; } var videoIds = []; for(var i = 0; i < res.items.length; i++) { var id = res.items[i].snippet.resourceId.videoId; if($.inArray(id, videoIds) != -1) { continue; } videoIds.push(id); document.write('<iframe src="http://www.youtube.com/embed/' + videoIds + '"></iframe>'); } //videoIdsの取得成功 // alert(videoIds.join("\n") ); // alert('<iframe src="http://www.youtube.com/embed/' + videoIds + '"></iframe>'); //document.write(videoIds); }, "error": function(res, status) { //error処理 alert("error!"); return ""; } } ); }, "error": function(res, status) { //error処理 alert("error!"); return ""; } } ); }); </script>

問題は以下の部分です。

var videoIds = []; for(var i = 0; i < res.items.length; i++) { var id = res.items[i].snippet.resourceId.videoId; if($.inArray(id, videoIds) != -1) { continue; } videoIds.push(id); document.write('<iframe src="http://www.youtube.com/embed/' + videoIds + '"></iframe>'); }

上記コードですと、以下のように動画IDがプラスされる形で出力されてしまいます。

<iframe src="http://www.youtube.com/embed/動画ID1"></iframe> <iframe src="http://www.youtube.com/embed/動画ID1,動画ID2"></iframe> <iframe src="http://www.youtube.com/embed/動画ID1,動画ID2,動画ID3"></iframe>

これを以下のように一つ一つIDが出力されるようにfor文を修正したいのですが、方法がわかりません。

<iframe src="http://www.youtube.com/embed/動画ID1"></iframe> <iframe src="http://www.youtube.com/embed/動画ID2"></iframe> <iframe src="http://www.youtube.com/embed/動画ID3"></iframe>

どなたか方法を教えていただけないでしょうか。
宜しくお願い致します。

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

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

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

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

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

guest

回答2

0

ベストアンサー

document.write('<iframe src="http://www.youtube.com/embed/' + videoIds + '"></iframe>');

ここのvideoIdsをidに変えればいけますね

投稿2017/05/11 08:17

yoorwm

総合スコア1305

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

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

no23h

2017/05/11 08:44

早速のご回答ありがとうございました。 助かりました!
guest

0

videoIdsが配列のままだからだと思います。
以下のようにしてみてはどうでしょうか。

javascript

1document.write('<iframe src="http://www.youtube.com/embed/' + videoIds[i] + '"></iframe>');

追記: yoorwmさんの方が適切です。

投稿2017/05/11 08:17

編集2017/05/11 08:18
m.f.

総合スコア81

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

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

no23h

2017/05/11 08:45

早速のご回答ありがとうございました。 m.f.様の内容でもうまく動作しました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問