javascript - Vuejs 无法加载 svg 图片?

标签 javascript webpack vue.js

在我的一个组件中,我试图加载 svg 图像,但 vuejs/webpack 失败。

这是我的代码:

<template>
    <img src="../../assets/public/images/sad.svg" />
</template>

<script>
export default {}
</script>

错误:

ERROR in ./src/assets/public/images/sad.svg
Module parse failed: /home/cabox/workspace/src/assets/public/images/sad.svg Line 1: Unexpected token < You may need an appropriate loader to handle this file type.
|
|
| @ ./~/vue-html-loader!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/tooltip.vue 1:205-258 1:592-645

据我了解,Vuejs(或 Webpack)试图解释 .svg 的内容。这不是我想要的。

这是我的 svg webpack 配置:

{ test: "\.svg", loader: "file-loader?mimetype=image/svg+xml" },

感谢您的帮助。

最佳答案

这个对我有用:

{test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=image/svg+xml'}

它是一个正则表达式,可以按照您正在寻找的方式将任何具有 svg 扩展名的文件作为静态资源进行处理。

我将它与其他字体加载器一起用于 bootstrap 或其他 glyphfonts:

{test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/font-woff'},
{test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/octet-stream'},
{test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, loader: 'file'},
{test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=image/svg+xml'}

使用该正则表达式,您可能可以将加载程序更改为文件并像您使用的那样内联它。

关于javascript - Vuejs 无法加载 svg 图片?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35012647/

相关文章:

vue.js - 在 TDD 期间模拟 Vue 实例上的方法

html - 如何居中用 vue 创建的分页栏?

javascript - 导入 iPython 自定义小部件函数(文件结构?)

javascript - 导航栏中的下拉菜单与 JavaScript 不工作

javascript - 使用 Grunt 和 Webpack 的结构

vue.js - vue cli如何在index.html中创建自定义 block 和 Hook ?

webpack - 以webpack链方式编写MiniCssExtractPlugin

javascript - 如何在 Jasmine 中的所有套件之前运行先决条件

javascript - axios 获取参数数组

vue.js - 是否可以根据父组件的 props 在扩展 : property, 中动态添加图表类型?