Gatsby SCSS 模块未编译

问题描述

使用 sass 1.32.8 运行 Gatsby 3.0.1 版。我刚刚开始尝试一些东西,但遇到了一个我无法解决的奇怪问题。

./gatsby-config.js

module.exports = {
  /* Your site config here */
  plugins: [
    {
      resolve: `gatsby-plugin-sass`,options: {
        implementation: require("sass"),},],}

./src/pages/index.js

import React from "react"
import homeStyles from '../styles/scss/index.module.scss'

export default function Home() {
  return <div className={homeStyles.testElement}>Hello World!</div>
}

./styles/scss/index.module.scss

.testElement {
  font-size: 72px;
}

我得到的错误Attempted import error: '../styles/scss/index.module.scss' does not contain a default export (imported as 'homeStyles').

如果我尝试使用 import * as homeStyles from '../styles/scss/index/module.scss错误是:Attempted import error: 'testElement' is not exported from '../styles/scss/index.module.scss' (imported as 'homeStyles').

在不确切知道插件如何工作的情况下,我看不到任何会导致这种情况的问题。

解决方法

像这样使用:

module.exports = {
  /* Your site config here */
  plugins: [
    {
      resolve: `gatsby-plugin-sass`,},],}

您不需要添加额外的实现来处理 CSS 模块,因此您可以省略它们。

此外,根据此GitHub thread,解决方案是将插件降级为v4

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...