[Vuejs]-Vue.js – Image not showing up

0👍

ImageName must be an URL not path. Like a simple img with html

0👍

Refer this : 
<template>
    <div class="container">
        <h4>On Number Add Show Image</h4>

        <div class="row">
            <div class="col-8 border">
                <form action="" @submit.prevent="showImage(number)" ref="form">
                    <label for="number" class="form-label text-start">Image Number :</label>
                    <input type="number" class="form-control required" name="number" id="number" v-model="number"
                        ref="number" /><br>
                    <button type="submit" class="btn btn-primary mt-3">Submit</button>
                </form>
            </div>
            <div class="col-4 border">
                <button type="submit" @click="reset()" class="btn btn-primary mt-3">Reset</button>
                <h6 class="mt-3">List to Number Present</h6>
                <pre>
                    {{Object.keys(images)}}
                </pre>
            </div>
        </div>
        <OnInputImageShow :url="url"/>
    </div>
</template>
<script>
import OnInputImageShow from "./OnInputImageShow.vue";
export default {
    name: 'OnInputImage',
    components:{
        OnInputImageShow,
    },
    data() {
        return {
            number: '',
            url: '',
            images: [
                '',
                'https://fakestoreapi.com/img/71-3HjGNDUL._AC_SY879._SX._UX._SY._UY_.jpg',
                '',
                'https://cdn.pixabay.com/photo/2015/04/23/22/00/tree-736885_1280.jpg',
            ]
        }
    },
    methods: {
        showImage(number) {
            // console.log(number);
            this.url = this.images[number];
        },
        reset(){
            this.url = '';
            this.number ='';
        }

    },
    mounted() {
        this.url = '';
    },

}
</script>
<style></style>

----------------------
OnInputImageFormShow.vue
<template>
    <div class="row border">
        <div class="col d-flex justify-content-center">
            <img :src="url" v-if="url" width="350" height="300">
        </div>
    </div>
</template>
<script>
export default {
    name: 'OnInputImageShow',
    props: [
        'url'
    ],
}
</script>
<style></style>

Leave a comment