javascript - Webpack 不捆绑 SCSS / CSS
问题描述
我正在尝试使用SCSS
.
"scripts": {
"start": "webpack-dev-server --config webpack.dev.js --mode development"
},
"devDependencies": {
"@babel/core": "^7.6.0",
"@babel/preset-env": "^7.6.0",
"babel-loader": "^8.0.6",
"css-loader": "^3.2.0",
"html-webpack-plugin": "^3.2.0",
"live-server": "^1.2.1",
"node-sass": "^4.12.0",
"sass-loader": "^8.0.0",
"style-loader": "^1.0.0",
"webpack": "^4.39.3",
"webpack-cli": "^3.3.8",
"webpack-dev-server": "^3.8.0"
}
我的webpack.config.js文件
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
entry: {
index: './src/index.js'
},
devServer: {
port: 8080
},
module: {
rules: [
{
test: /\.css$/i,
use: ["style-loader", "css-loader"]
},
{
test: /\.s[ac]ss$/i,
use: ['style-loader', 'css-loader', 'sass-loader']
},
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env']
}
},
]
},
plugins: [
new HtmlWebpackPlugin({
template: './src/index.html',
inject: true,
chunks: ['index'],
filename: 'index.html'
})
]
}
我的应用程序结构如下:
当我跑npm start
起来看到我scss
作为一个css
文件出现在我的index.html
.
不过,它看起来根本没有捡起它。
解决方案
我看到您的 webpack 配置不正确,因为您使用的是 scss 而不是 css
下面是我的配置。你可以在这里查看更多
{
test: /\.scss$/,
use: [
'style-loader',
MiniCssExtractPlugin.loader,
{
loader: "css-loader",
options: {
minimize: true,
sourceMap: true
}
},
{
loader: "sass-loader"
}
]
},
然后像这样导入你的js文件
import "main.scss";
推荐阅读
- ios - 如何在 iOS、Swift 的 Collection View Cell 中停止捕获会话
- jquery - 到达其他字段中的日期时自动更新数据库字段
- python - 如何在 Keras.Model 中获得 l2 正则化损失值?
- javascript - 在服务器端将隐藏值数据作为数组发送时出现错误
- java - 有没有办法将 String.format 传递给 thymeleaf 模板?
- oracle-cloud-infrastructure - 我们是否需要启用 VM 监控才能使用 REST API 或 Java SDK 监控 Oracle 云计算 VM?
- jquery - 用 html5 结束视频的海报
- hdf5 - 如何使用 pytables 取消引用外部链接列表?
- c# - 使用 linq 查询的左连接不适用于数据表中的空列
- r - 如何根据 R 中的一些常用词进行计数