3

我正在使用 Angular2 beta.15 和 webpack 1.12.14。

我有一个 .css 和一个 .scss 文件app.component.ts作为这样的全局模式。

  @Component({
    selector: 'my-app',
    templateUrl: 'app/app.component.html',
    styles: [
      require('../stylesheets/css/main.min.css'),
      require('../sass/example.scss')
    ],
    encapsulation: ViewEncapsulation.None,
  })

而且,在.css文件内部,一些字体被导入如下,

@font-face {
    font-family: 'Helvetica Neue';
    src: url(fonts/light/helvetica-neue-light.eot) format("eot"), 
         url(fonts/light/helvetica-neue-light.woff2) format("woff2"),   
         url(fonts/light/helvetica-neue-light.woff) format("woff"), 
         url(fonts/light/helvetica-neue-light.ttf) format("truetype");
    font-weight: 300;
    font-style: normal
}

webpack.config.js中,我有、 和字体的加载器.css,如下所示.scss

  {
    test: /\.scss$/,
    exclude: /node_modules/,
    loaders: ['raw-loader', 'sass-loader'] // sass-loader not scss-loader
  },
  {
       test: /.(png|woff(2)?|eot|ttf|svg)(\?[a-z0-9=\.]+)?$/,
       loader: 'url-loader'
  },
  {
    test: /\.css$/,
    loaders: ['style', 'css']
  },

当我运行webpack -display-error-details时,根本没有错误,但是当我启动服务器运行我的应用程序时,出现如下错误

EXCEPTION: Error during instantiation of Token Promise<ComponentRef>!.
ORIGINAL EXCEPTION: Expected 'styles' to be an array of string

如果我将 css 加载器更改为

  {
    test: /\.css$/,
    loader: 'url-loader'  //or use 'raw-loader'
  },

这些异常消失了,应用程序启动了,但是我在浏览器的控制台中收到了这些字体的一些 404 请求错误,它们根本没有加载。那么,你能给我一些指点吗?我怀疑我的加载程序设置有问题。

4

3 回答 3

1

当您将多个加载器链接在一起时,它们的操作顺序是从右到左完成的。

然后从加载器得到的代码被传递给下一个。在这种情况下,您希望像这样链接raw-loaderandurl-loader以获得所需的结果:

loaders: ['raw-loader', 'url-loader']

由于您首先需要将字体网址自动转换为样式中编码的 base64,因此您必须首先url-loader在您的链中调用。然后,由于您希望将此文件作为 module.exports 导入,因此您调用raw-loader.

所以在链中会发生以下情况:

  1. url-loader: 将所有对静态资源的 url 引用转换为base64:data.
  2. raw-loader:获取您的文件,并用字符串包装其整个代码,然后通过添加使其可导入module.exports='string'
于 2016-04-24T03:35:52.220 回答
0
        Just Try once to keep under one dir both font and css

        // and give the reference onces in webpack.config.rb

         # Set this to the root of your project when deployed:
         http_path = "/"
         css_dir = "app/assets/css"
         sass_dir = "app/assets/sass"
于 2016-04-22T05:00:51.637 回答
0

试试这个:

@Component({
selector: 'my-app',
templateUrl: 'app/app.component.html',
styles: [
  require('../stylesheets/css/main.min.css').toString(),
  require('!style-loader!css-loader!less-loader!../less/example.less').toString()
]})

我知道命令少,类似的命令应该可用于 scss

于 2016-12-03T11:43:18.127 回答