首页 > 解决方案 > 为什么 webpack 在 base64 中转换 require('path to img.png')?

问题描述

我有一个聊天记录和一个存储所有历史记录的 JSON 文件。所有图像/视频/音频链接都需要('媒体路径')。

但是,由于某种原因,当使用 vue-cli-service serve 或 vue-cli-service build 时,webpack 会跳过我用于 Emoji 的图像,而不是将其包含在 dist 文件夹中,而是将其转换为 base64 字符串。

JSON 看起来像这样:

          { 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' } },

我的 Emoji 类型消息由于某种原因被转换为 base64,并且 png 图像不包含在最终构建中。

在浏览器中,我得到以下条目:{author: "support", type: "emoji", data: {src: ""}}

但它应该看起来像这样:{author: "support", type: "emoji", data: {src: "img/smiling-face.png"}}

这只发生在smileing-face.png上,任何其他图像,包括其他png都正确显示并包含在构建中,所以有人能说什么是错的吗?

链接到图片“smiling-face.png”:https ://mega.nz/#!Ze5UzK7A!MdV23KlEou4ByfOlN0aCBc8N7KAGkvNnwPH1YFiltBE

标签: jsonwebpackbase64pngvue-cli

解决方案


Vue 会将任何低于 10kb 的图像编码为 base64 并内联到您的 JS 包中。

您可以通过将限制设置为 -1 来修改vue.config.js以删除它:

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

推荐阅读