4

I'm using VueJS in version 2.6.11 with vue-material 1.0.0-beta-11.

I've read through the internet about loading images into Vue through vue-loader etc. but none of that helped.

<md-card-media md-ratio="4:3">
      <img :src="getImgUrl(muscle.name)" alt="Skyscraper">
</md-card-media>

This is my HTML element which is supposed to render images.

The getImgUrl is defined in such a way:

methods: {
    getImgUrl: imgName => {
      let urlName = imgName.replace(/\s/g, '')
      return require(`@/assets/images/${urlName}.png`)
    }
}

The result of the code above:

<img src="...truncatedForReadibility" alt="Skyscraper" crossorigin="Anonymous">

vue.config.js

module.exports = {
    publicPath: '/siluets/',
    configureWebpack: {
        module: {
            rules: [
                {
                    test: /\.(png|jpe?g|gif)$/i,
                    loader: 'vue-loader',
                    options: {
                        esModule: false,

                    },
                },
            ],
        }

    }
}

The browser is not showing up any images. I can't figure it out by myself

10
  • 2
    Please provide your webpack.config.js or vue.config.js Commented Apr 21, 2020 at 22:41
  • I don't recommend using methods in template content; they get run every tick. Try using a computed property instead Commented Apr 21, 2020 at 22:41
  • @Ashish provided after edit Commented Apr 21, 2020 at 22:44
  • Are you sure you're looking at the correct element? I ask as your source does not have that crossorigin attribute Commented Apr 21, 2020 at 22:44
  • Why are you using the vue-loader for images? Why did you add that rule at all? Webpack is configured to load images via the url-loader / file-loader by default Commented Apr 21, 2020 at 22:45

2 Answers 2

2

You should not use vue-loader for images. Use url-loader or file-loader as shown os docs:

https://vue-loader.vuejs.org/guide/asset-url.html#transform-rules

Sign up to request clarification or add additional context in comments.

Comments

0

You can access the image url in the [object Module] using the dot notation to access the default property.

In your getImgUrl method you can do this by returning: require(`@/assets/images/${urlName}.png`).default

methods: {
    getImgUrl: imgName => {
      let urlName = imgName.replace(/\s/g, '')
      return require(`@/assets/images/${urlName}.png`).default
    }
}

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.