skip to Main Content

I come from a React background but I have to use Vue (first-time) for a code assessment. I tried creating a re-usable image component with wai-aria accessibility but whatever I try, the image itself will not show up. Only the ALT-text will show. The WAI-ARIA works properly. The core issue is the image not showing up here. I have asked GPT, Bard, Discord servers (no responses), tried YouTube, but I cannot find a solution to my problem.

Image component code:

<template>
    <div>
        <img :src="imageName" :alt="imageAlt" />
        <span aria-label="imagecontent" role="contentinfo" class="aria">{{ ARIAText }}</span>
    </div>
</template>

<style>
.aria {
    height: 1px;
    width: 1px;
    position: absolute;
    overflow: hidden;
    top: -10px;
};
</style>

<script>
export default {
    name: 'ImageComp',
    props: {
        imageName: String, 
        imageAlt: String,
        ARIAText: String
    },
};
</script>

Main component:

<template>
    <header>
            <ImageComp imageName="../assets/icons/logo.png" imageAlt="****** Logo"
                ARIAText="This is the logo of *****. Dit is het logo van ******" />
    </header>
</template>

<script>
import ImageComp from './ImageComp.vue';


export default {
    name: 'TopBanner',
    components: {
        ImageComp,
    },
     props: {
        imageName: String,
        imageAlt: String,
        ARIAText: String
    },
};
</script>

I have tried to importing the image the react way as a component and use the component as the image SRC, that did not work, I tried require, require@, I tried using different images, I tried deleting the style applied from the .aria element, nothing works. I tried asking AI, Webdev discords, tried YouTube video’s. I am at a complete loss. What do I need to do?

2

Answers


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

    Login or Signup to reply.
  2. 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>
    
    Login or Signup to reply.
Please signup or login to give your own answer.
Back To Top
Search