Webpack не копирует файлы шрифтов
Я пытаюсь настроить конфигурацию веб-пакета для моего приложения vue2. Следует также создать CSS из Sass. Итак, я взглянул на плагин mix от laravel, чтобы создать свой собственный конфиг webpack. Работает нормально, но когда я включаю шрифт в свой файл sass (@import "~font-awesome/scss/font-awesome";
), Я получаю эту ошибку:
Module build failed: ModuleNotFoundError: Module not found: Error: Can't resolve '../fonts/fontawesome-webfont.eot?v=4.7.0' in '[PATH]\client\styles'
Webpack должен автоматически скопировать файлы шрифтов FA в [PATH]\client\fonts\
как Laravel-Mix. Я перепробовал много решений, но никто не работал. мой webpack.config.js
похоже:
const path = require('path'),
webpack = require('webpack'),
ExtractTextPlugin = require("extract-text-webpack-plugin"),
FriendlyErrorsWebpackPlugin = require("friendly-errors-webpack-plugin"),
postCssOptions = [require('autoprefixer')];
module.exports = {
entry: {
'main': [
'./client/scripts/main.js',
'./client/styles/main.scss'
]
},
output: {
path: path.resolve(__dirname, 'public'),
publicPath: './',
filename: 'js/[name].js'
},
resolve: {
extensions: [ '*', '.js', '.vue' ],
alias: {
'vue$': 'vue/dist/vue.common.js',
'vue-router$': 'vue-router/dist/vue-router.common.js'
}
},
module: {
rules: [
{
test: /\.vue$/,
loader: 'vue-loader',
options: {
loaders: {
js: 'babel-loader?presets[]=es2015',
scss: ExtractTextPlugin.extract({
use: 'css-loader!sass-loader',
fallback: 'vue-style-loader'
}),
sass: ExtractTextPlugin.extract({
use: 'css-loader!sass-loader?indentedSyntax',
fallback: 'vue-style-loader'
}),
css: ExtractTextPlugin.extract({
use: 'css-loader',
fallback: 'vue-style-loader'
}),
postcss: postCssOptions
}
}
},
{
test: /\.css$/,
loader: ExtractTextPlugin.extract({
use: 'css-loader',
fallback: 'style-loader'
})
},
{
test: /\.s[ac]ss$/,
loader: ExtractTextPlugin.extract({
use: 'css-loader!sass-loader',
fallback: 'style-loader'
})
},
{
test: /\.html$/,
loaders: ['html-loader']
},
{
test: /\.(png|jpe?g|gif)$/,
loader: 'file-loader',
options: {
name: 'images/[name].[ext]?[hash]'
}
},
{
test: /\.(woff2?|ttf|eot|svg|otf)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: 'file-loader',
options: {
name: 'fonts/[name].[ext]?[hash]'
}
}
]
},
devtool: '#source-map',
plugins: [
new ExtractTextPlugin({
filename: "./css/[name].css",
allChunks: true
}),
new FriendlyErrorsWebpackPlugin ({
shouldClearConsole: true
}),
new webpack.LoaderOptionsPlugin({
minimize: isProduction,
options: {
postcss: postCssOptions,
context: __dirname,
output: { path: './' }
}
})
]
}
2 ответа
Теперь я решил это с помощью resolve-url-loader
загрузчикам файлов sass/scss, поэтому у меня есть:
{
test: /\.s[ac]ss$/,
loader: ExtractTextPlugin.extract({
use: 'css-loader!resolve-url-loader!sass-loader?sourceMap',
fallback: 'style-loader'
})
},
{
test: /\.(woff(2)?|ttf|eot|svg|otf)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: 'file-loader',
options: {
name: 'fonts/[name].[ext]?[hash]',
publicPath: '/'
}
}
помните, чтобы добавить ?sourceMap
загрузчику sass https://www.npmjs.com/package/resolve-url-loader
Пожалуйста, используйте url-загрузчик для обработки файлов такого типа. https://github.com/webpack-contrib/url-loader