4

使用 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').

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

4

1 回答 1

1

像这样使用它:

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

你不需要添加额外的实现来使用 CSS 模块,所以你可以省略它们。

此外,根据这个GitHub 线程,解决方案是将插件降级为v4.

于 2021-03-05T13:09:55.787 回答