Menu

Sass

Next.jsは、パッケージをインストールした後、.scss.sassの両方の拡張子でSassとの統合を組み込みでサポートしています。CSSモジュールと.module.scssまたは.module.sass拡張子を使用して、コンポーネントレベルのSassを使用できます。

まず、sassをインストールします:

Terminal
npm install --save-dev sass

補足:

Sassは、それぞれ独自の拡張子を持つ2つの異なる構文をサポートしています。 .scss拡張子はSCSS構文を使用する必要があり、 .sass拡張子はインデント構文("Sass")を使用する必要があります。

どちらを選んでよいかわからない場合は、CSSのスーパーセットであり、インデント構文("Sass")を学ぶ必要のない.scss拡張子から始めてください。

Sassオプションのカスタマイズ

Sassオプションを設定したい場合は、next.configsassOptionsを使用します。

next.config.ts
import type { NextConfig } from 'next'
 
const nextConfig: NextConfig = {
  sassOptions: {
    additionalData: `$var: red;`,
  },
}
 
export default nextConfig
next.config.js
/** @type {import('next').NextConfig} */
 
const nextConfig = {
  sassOptions: {
    additionalData: `$var: red;`,
  },
}
 
module.exports = nextConfig

実装

implementationプロパティを使用して、使用するSass実装を指定できます。デフォルトでは、Next.jsはsassパッケージを使用します。

next.config.ts
import type { NextConfig } from 'next'
 
const nextConfig: NextConfig = {
  sassOptions: {
    implementation: 'sass-embedded',
  },
}
 
export default nextConfig
next.config.js
/** @type {import('next').NextConfig} */
 
const nextConfig = {
  sassOptions: {
    implementation: 'sass-embedded',
  },
}
 
module.exports = nextConfig

Sassの変数

Next.jsは、CSSモジュールファイルからエクスポートされたSassの変数をサポートしています。

例えば、エクスポートされたprimaryColorのSass変数を使用する:

app/variables.module.scss
$primary-color: #64ff00;
 
:export {
  primaryColor: $primary-color;
}
pages/_app.js
import variables from '../styles/variables.module.scss'
 
export default function MyApp({ Component, pageProps }) {
  return (
    <Layout color={variables.primaryColor}>
      <Component {...pageProps} />
    </Layout>
  )
}