我们正在为Angular 2项目使用Angular CLI。该项目使用一个存储在node_modules文件夹中的大型SVG,并且需要在运行时下载svg。
如果我们将它添加到angular-cli.json
中"addons": [
"../node_modules/my_module/**/*.svg"
],
然后在我们的一个组件中require(../node_modules/my_module/icons.svg);
svg文件被哈希并按预期工作。
这个解决方案的问题是测试失败,业力输出:
ERROR in ./node_modules/my_module/icons.svg
Module parse failed: path-to-svg/node_modules/my_module/icons.svg Unexpected token (1:0)
You may need an appropriate loader to handle this file type.
| <svg>
| <defs>
问题是将此文件包含在捆绑包中的正确方法是什么?
Karma.conf.js:
module.exports = function (config) {
config.set({
basePath: '../',
frameworks: ['jasmine', 'angular-cli'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-phantomjs-launcher'),
require('karma-remap-istanbul'),
require('angular-cli/plugins/karma')
],
files: [
{ pattern: './src/test.ts', watched: false }
],
preprocessors: {
'./src/test.ts': ['angular-cli']
},
remapIstanbulReporter: {
reports: {
html: 'coverage',
lcovonly: './coverage/coverage.lcov'
}
},
angularCli: {
config: './angular-cli.json',
environment: 'dev'
},
reporters: ['progress', 'karma-remap-istanbul'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['PhantomJS'],
singleRun: false
});
};