Home >Web Front-end >JS Tutorial >How can I dynamically render images in my Vue.js and Webpack application?
In a Vue.js and webpack application, you may encounter situations where you need to display images dynamically based on variables. However, if you are encountering issues where dynamic images are not being displayed correctly, it's important to rectify the underlying problem.
One instance where this issue often arises is when you store the file names of images in a computed property that retrieves a Vuex store variable populated asynchronously on beforeMount. Utilizing the v-bind:src directive, you intend to concatenate the dynamic file name with a static asset path to create the image source. However, this approach may not always yield the desired results.
Instead, a more robust solution is to leverage webpack's require.context() method. This method allows you to access files from specific directories based on provided regular expressions. For example, you can use this method to obtain all .png files from the assets directory.
To implement this solution, define a method in your Vue.js component that accepts the image file name as an argument. Within this method, use require.context to retrieve the image path and return it. In your HTML template, bind the src attribute of the img tag to this method.
<div class="col-lg-2" v-for="pic in pics"> <img :src="getImgUrl(pic)" v-bind:alt="pic"> </div>
getImgUrl(pet) { var images = require.context('../assets/', false, /\.png$/) return images('./' + pet + ".png") }
By utilizing the require.context method in conjunction with your dynamic method, you can effectively resolve the issue of dynamic image rendering in your Vue.js and webpack application.
The above is the detailed content of How can I dynamically render images in my Vue.js and Webpack application?. For more information, please follow other related articles on the PHP Chinese website!