🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

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

Q&A

解決済

2回答

3565閲覧

vue.js Flickr APIから猫と犬の画像を取得するには

kensuzu5

総合スコア2

JavaScript

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

0グッド

0クリップ

投稿2020/11/25 10:34

編集2020/12/05 09:58

前提・実現したいこと

vue.jsで猫と犬の画像を4枚ずつ表示させるため設定を行っています。

・this.photosを上書きしてしまって片方だけ表示しています。

現在の状態

イメージ説明

質問内容

下記のコードにスプレッド構文やforEach()を使って犬と猫の画像を両方表示させるにはどのような設定をすればよいのかアドバイスお願いします。

this.photos = data.photos.photo.map(photo => ({

コード

index.html

1 2<div class="image-gallery__item" 3 v-for="photo in photos" 4 > 5 <a 6 v-bind:key="photo.id" 7 v-bind:href="photo.pageURL" 8 tooltip="photo" 9 class="d-inline-block" 10 target="_blank" 11 > 12 <img 13 v-bind:src="photo.imageURL" 14 v-bind:alt="photo" 15 width="150" 16 height="150" 17 > 18 </a> 19 </div>

main.js

1new Vue({ 2 el: '#gallery', // elオプションの値に '#gallery' を設定 3 4 components: { 5 6 }, 7 8 9 data: { 10 // 利用するデータを設定 11 12 photos:[], 13 14 }, 15 16 17 18 created() { 19 // Vueが読み込まれたときに実行する処理を定義 20 this.fetchImagesFromFlickr('cat'); 21 this.fetchImagesFromFlickr('dog'); 22 }, 23 24 25 26 27 28 methods: { 29 fetchImagesFromFlickr(searchText) { 30 31 const url = getRequestURL(searchText); 32 33 34 35 36 $.getJSON(url, (data) => { 37 if (data.stat !== 'ok') { 38 //this.photos(); 39 return; 40 } 41 42 43 44 45 46 if (fetchedPhotos.length === 0) { 47 return; 48 } 49 50 51 52 53 const imageData = fetchedPhotos.map(photo => ({ 54 id: photo.id, 55 imageURL: getFlickrImageURL(photo, 'q'), 56 pageURL: getFlickrPageURL(photo), 57 text: getFlickrText(photo), 58 })); 59 }); 60 }, 61 }, 62 }); 63

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

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

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

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

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

plasticgrammer

2020/11/25 11:58

『concatを使って』と繰り返していますが、これは配列のconcatメソッドを使うという意味なのでしょうか? concatを使うことが目的なのですか?犬と猫の画像両方表示させることができればいいのですよね? 上記の点について明記をお願いします。
kensuzu5

2020/11/25 22:51 編集

説明不足申し訳ございません。 ・配列のconcatメソッドを使うという意味です。 ・concatを使うことが目的です。
kensuzu5

2020/12/05 04:57

上記のコメントにconcatを使うと書きましたが、他に何か方法があればアドバイスお願いします。 concatは使わずに修正しようと思います。
guest

回答2

0

自己解決

const imageData = (略)

this.photos = [...this.photos, ...imageData]

に修正をしたら画像が4枚ずつ表示されました。

投稿2020/12/05 10:53

kensuzu5

総合スコア2

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

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

naoya0922

2021/02/08 12:35

質問失礼します。 ...this.photosはどこからもってきたのでしょうか?
guest

0

テンプレートではthis.photosの中の猫犬画像を表示しているんですよね?

js

1const imageData = () 2 3this.photos = [...this.photos, ...imageData]

とすれば、this.photosの中身は

[ { id: ..., imageURL: ..., pageURL..., text: "猫" }, { id: ..., imageURL: ..., pageURL..., text: "猫" }, { id: ..., imageURL: ..., pageURL..., text: "犬" }, { id: ..., imageURL: ..., pageURL..., text: "犬" }, ]

となるはずです。

投稿2020/12/05 05:40

neko_daisuki

総合スコア2090

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

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

kensuzu5

2020/12/05 09:14

コメントありがとうございます。 const imageData = fetchedPhotos.map(photo => ({ this.photos = [...this.photos, ...imageData]; で実行したところUncaught SyntaxError: Unexpected token '.'エラーが出てしまいました。 this.photosの書き方が間違っていますでしょうか?
neko_daisuki

2020/12/05 09:19

imageData は質問を編集する前の内容を想定していましたが、 現在の this.photos = data.photos.photo.map(photo => ({ ... }) で取得できているのなら const imageData = data.photos.photo.map(photo => ({ ... }) this.photos = [...this.photos, ...imageData] としてみてください。
kensuzu5

2020/12/05 09:56

ありがとうございます。 無事に犬と猫の画像を4枚ずつ取得することができました。 最後に確認ですが現在の状態で左に-->の消し方をアドバイスお願いします。 何度もすいません。
neko_daisuki

2020/12/05 10:26

これは掲載してるテンプレートの外側にあるコメントではないでしょうか。 <!-- コメント --> ←こいつ それを消せば消えると思います。
kensuzu5

2020/12/05 10:46

ありがとうございます。 無事解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問