Learn the basics of binding data to the HTML image tag using Vue.js.
You can build static websites, MVPs and prototypes with single page applications (SPAs). Sometimes you deal with more complex cases such as building large applications, working with APIs and authentication.
Vue.js is good at both. And today we’ll be dealing with dynamic images. Think about the user profile picture that is fetched from the backend server with an API get request.
How to use img src in Vue.js
You should use a Vue.js v-bind:src
or just :src
to dynamically set image src.
new Vue({
el: "#app",
data: {
image: 'https://picsum.photos/id/1005/600/200'
}
})
<div id="app">
<h2>Image:</h2>
<img :src="image" style="width:100%;" alt="">
</div>
Another example
The example below shows how to get a dynamic image from the third-party service when you click on the Get a dynamic image
button. It will then bind this image to the HTML image tag.
new Vue({
el: "#app",
data: {
userProfilePic: null
},
methods: {
getImage () {
this.userProfilePic = 'https://picsum.photos/id/1005/600/200'
}
}
})
HTML
<div id="app">
<h2>Dynamic image in Vue.js:</h2>
<p v-if="userProfilePic"><img style="width:100%" :src="userProfilePic" alt=""></p>
<p><a href="#" @click="getImage()">Get a dynamic image</a></p>
</div>
The result
If you find this post useful, please let me know in the comments below and subscribe to my newsletter.
Cheers,
Renat Galyamov
Want to share this with your friends?
👉renatello.com/bind-img-src-vue-js
PS: Make sure you check other Vue.js tutorials, e.g. redirect to login page in Vue.js.
Incoming search terms:
I wrote this but it did’t work I can’t find error. Please if you can help me Write me!
Hey Rustam! Do you get an error in console? Could you please share it?
is not displaying image.
but
{{ zimezs[imez][0] }}
is displaying path of image that is :
~/assets/pikcrs/apple.jpg
———–
https://github.com/zava810/zbc