Why webpack converts require('path to img.png') in base64?

情到浓时终转凉″ 提交于 2021-02-10 14:38:48

问题


I have a chat, and a JSON file where all the history is stored. All images/video/audio link to require('path to media').

However, for some reason, when using vue-cli-service serve or vue-cli-service build, webpack skips my image which is used for Emoji, not including it in dist folder, but converting it to base64 string.

JSON looks like this:

          { type: 'emoji', author: `me`, data: { src: require('../../Media/img/smiling-face.png') } },
          { type: 'text', author: `me`, data: { text: `Do you read me...`, meta: '✓✓ Read' } },
          { type: 'image', author: `support`, data: { src: require('../../Media/img/2.gif'), meta: '✓✓ Read' } },
          { type: 'image', author: `me`, data: { src: require('../../Media/img/1.jpg'), meta: '✓✓ Read' } },

My Emoji type message is converted to base64 for some reason, and the png image is not included in the final build.

In the browser I get the following entry: {author: "support", type: "emoji", data: {src: ""}}

But it should look like this: {author: "support", type: "emoji", data: {src: "img/smiling-face.png"}}

And this happens only with smiling-face.png, any other image, including other png is displayed correctly and included in the build, so can anyone say what's wrong?

Link to image "smiling-face.png": https://mega.nz/#!Ze5UzK7A!MdV23KlEou4ByfOlN0aCBc8N7KAGkvNnwPH1YFiltBE


回答1:


Vue will encode any images below 10kb into base64 and inline into your JS bundle.

You can amend vue.config.js to remove this by setting the limit to -1:

module.exports = {
  chainWebpack: config => {
    config.module
      .rule('images')
      .use('url-loader')
      .loader('url-loader')
      .tap(options => {
        options.limit = -1
        return options
      })
  }
}


来源:https://stackoverflow.com/questions/57077663/why-webpack-converts-requirepath-to-img-png-in-base64

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!