问题
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