我在项目中使用Webpack观看.scss和.ts文件。
我有一个包含scss文件的文件夹。
这是结构:
当我编辑app.scss文件中的内容时,Webpack会监视更改并重新编译。
当我编辑包含文件夹中的内容时,Webpack不会重新编译。
webpack.config.js
:
const path = require('path');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CopyWebpackPlugin = require('copy-webpack-plugin');
const devMode = process.env.NODE_ENV !== 'production';
let dist = 'wwwroot'
module.exports = {
entry: {
app: './src/js/app.js'
},
output: {
path: path.resolve(__dirname, dist),
filename: 'js/[name].min.js'
},
resolve: {
extensions: ['.ts', '.js']
},
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
cacheDirectory: true
}
}
},
{
test: /\.ts$/,
use: [
{
loader: 'awesome-typescript-loader',
options: { configFileName: path.resolve(__dirname, 'tsconfig.json') }
},
]
},
{
test: /\.s?[ac]ss$/,
use: ['style-loader', MiniCssExtractPlugin.loader, 'css-loader',
{
loader: "sass-loader",
options: {
includePaths: ["./node_modules/foundation-sites/scss"]
}
}
]
},
{
test: /\.(png|jp(e*)g|gif|svg)$/,
use: [
{
loader: 'file-loader',
options: {
name: "[name].[ext]",
outputPath: 'img/',
publicPath: '../images/',
}
}
]
},
{
test: /\.(woff|woff2|eot|ttf|otf)$/,
use: [
{
loader: 'file-loader',
options: {
name: "[name].[ext]",
outputPath: 'fonts/',
publicPath: '../fonts/',
}
}
]
},
{
test: /\.svg$/,
loader: 'svg-inline-loader',
options: {
name: "[name].[ext]",
outputPath: 'img/',
publicPath: '../images/',
}
}
]
},
resolve: {
alias: {
"jquery.validation": "jquery-validation/dist/jquery.validate.js"
}
},
plugins: [
new CleanWebpackPlugin(dist, {}),
new MiniCssExtractPlugin({
filename: "css/[name].min.css",
chunkFilename: "[id].css",
}),
new CopyWebpackPlugin([
{
from: './src/img',
to: 'images',
toType: 'dir'
}
]),
],
}
我不明白为什么它不能使用包含文件夹中的文件。 我的问题在哪里?
答案 0 :(得分:2)
将sass文件夹添加到您的包含选项中:
options: {
includePaths: ["./node_modules/foundation-sites/scss", "path-to-your-sass-folder"]
}