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

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

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

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Q&A

解決済

1回答

863閲覧

【Vue.js】スライダーの画像を動的に変更したい

katahik

総合スコア79

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

0グッド

0クリップ

投稿2021/10/21 03:17

編集2021/10/21 08:39

前提・実現したいこと

vue-image-lightboxで画像のスライダーを作成しています。
サーバーサイドからもらったデータによってスライダーの画像を動的に変更したい。

環境

Vue.js 2.6.10

発生している問題・エラーメッセージ

この3枚のいずれかの画像をクリックすれば、スライダー表示となりますが
イメージ説明

しかし、下のように画像が表示されません
![イメージ説明]

そこで、chromeのdevツールのVueで中身をみてみると下記のとおり、undefinedになっております。だから、画像が表示されないのではないかと思っております。
![イメージ説明]

該当のソースコード

show.vue

<template> <div> <figure> <a class="img-box img320" @click.prevent.stop="show(0)"> <img :src="challenge.post_main_image_url" :alt="post.post_main_image_filename"> </a> <figcaption>{{ post.main_image_title }}</figcaption> </figure> <figure> <a class="img-box img320" @click.prevent.stop="show(1)"> <img :src="post.post_sub1_image_url" :alt="post.post_sub2_image_filename" > </a> <figcaption>{{ post.sub1_image_title }}</figcaption> </figure> <figure> <a class="img-box img320" @click.prevent.stop="show(2)"> <img :src="post.post_sub2_image_url" :alt="post.post_sub2_image_filename" > </a> <figcaption>{{ post.sub2_image_title }}</figcaption> </figure> </div> </template> <script> import ImageLightBox from 'vue-image-lightbox'; require("vue-image-lightbox/dist/vue-image-lightbox.min.css"); export default { name: 'lightbox', components: { ImageLightBox, }, data() { return { post_id: this.$route.params.post_id, post: {}, post_main_image_url: '', post_sub1_image_url: '', post_sub2_image_url: '', media: [ { // src: "/uploads/1"とするとうまくいく thumb: this.post_main_image_url, src: this.post_main_image_url, id: 1 }, { thumb: this.post_sub1_image_url, src: this.post_sub1_image_url, id: 2 }, { thumb: this.post_sub2_image_url, src: this.post_sub2_image_url, id: 3 } ], } }, methods: { show: function (index) { this.$refs.lightbox.showImage(index) }, getPost() { this.$loading.load( this.$auth.api.get( 'su/posts/' + this.post_id, { params: {} } ).then(res => { this.post = res.data.post; this.post_main_image_url = res.data.post.post_main_image_url; this.post_sub1_image_url = res.data.post.post_sub1_image_url; this.post_sub2_image_url = res.data.post.post_sub2_image_url; console.log(this.post_main_image_url) console.log(this.post_sub1_image_url) console.log(this.post_sub2_image_url) // /uploads/1 }).catch(err => { this.$errorHandlers.initial(err); }) ) }, }, created() { this.getPost(); }, } </script>

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

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

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

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

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

guest

回答1

0

自己解決

vue-image-lightboxで実装することを諦めて、jQueryの lightbox で実装を行いました

投稿2021/10/22 07:40

katahik

総合スコア79

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問