Angular2 beta.15 と webpack 1.12.14 を使用しています。
app.component.ts
このようなグローバル パターンとして、1 つの .css ファイルと 1 つの .scss ファイルがあります。
@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 要求エラーが発生し、まったく読み込まれていません。それで、私にいくつかの指針を教えてもらえますか?ローダーの設定に問題があると思われます。