0%

Programmingプログラミングナレッジ

Posted:2019.08.20

Nuxt.jsでSassファイルをグローバルに使えるようにする

Nuxt.jsのフレームワークの中においては、単一コンポーネントファイル内であればSassなどが使え、ビルドした時にCSSへとコンパイルされます。ただ、そのVueファイル内でしか使えないので、共通スタイルとしてグローバルに使いたい場合もあるかと思います。そこで今回はNuxt.jsでグローバルにSassを使う方法を備忘録として残しておきたいと思います。

 

Nuxt.jsでSassを使う場合には「node-sass」と「sass-loader」のモジュールパッケージが必要となります。yarnもしくはnpm経由でローカルのモジュールフォルダにインストールしていきます。

$ cd プロジェクトディレクトリ

$ yarn add --dev node-sass sass-loader
もしくは
$ npm install --save-dev node-sass sass-loader

 

インストールが終わると「package.json」のdevDependenciesのリストに追加されているのが確認できます。

【package.json】※一部抜粋

{
 "devDependencies": {
  .......
  "node-sass": "^4.12.0",
  "sass-loader": "^7.2.0",
  .......
 }
}

 

次に、プロジェクトルート直下のassetsディレクトリ配下に使いたいSassファイルを設置していきます。もちろんアンダーバーをつけてパーシャルファイルとし、Sassファイルを分割することも可能です。

/
 ┣ assets
  ┗ scss
   ┣ common.scss
   ┣ _base.scss
   ┗ _layout.scss

 

そして、プロジェクト直下にある「nuxt.config.js」にあるCSSプロパティの値に対象のSassファイルをルートパスで指定します。@を入れることでプロジェクトルートを基準としたルートパスで指定できます。

【nuxt.config.js】※一部抜粋

export default {
 css: [
  '@/assets/scss/common.scss'
 ]
}

 

デベロッパーツールで確認してみると、Sassファイルがコンパイルされていることが確認できます。

Nuxt.jsでSassファイルをグローバルに使えるようにする

 


 

Vueのプロジェクトにおいては、基本的にコンポーネント単位でスタイルも管理することが多いかと思いますが、変数やミックスインなど共通で使えるものも残しておきたいですよね。そんな時にはこのようにグローバルとして使えるSassを用意しておくと便利ですね。

(参考にさせていただいたサイト)
Nuxt.js API: css プロパティ

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】