0%

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

Posted:2019.08.22

Nuxt.jsで「style-resources-module」を使って、グローバルで変数やmixinなどを使えるようにする

前回記事「Nuxt.jsでSassファイルをグローバルに使えるようにする」の続きになりますが、グローバルで使えるSassファイル内に定義した変数やmixinをVueコンポーネントファイル内のstyleで使えるようにする方法のメモです。そのままですとSassとしてスタイルは定義できますが、コンポーネント内で変数やmixinを使うと、定義されていませんとエラーが出てしまいます。

 

そこで「style-resources-module」というモジュールを使うことで、コンポーネント内でもグローバルにあるSassファイルの変数やmixinが使えるようになります。

【nuxt-community/style-resources-module】
https://github.com/nuxt-community/style-resources-module

 

詳しくは公式のGitHubにドキュメントがありますが、とても簡単ですのでこちらでもまとめておこうと思います。まずはNuxtプロジェクト内にモジュールをインストールしていきます。

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

$ yarn add --dev @nuxtjs/style-resources
 or
$ npm install --save-dev @nuxtjs/style-resources

 

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

【package.json】※一部抜粋

{
 "devDependencies": {
  .......
  "@nuxtjs/style-resources": "^1.0.0",
  .......
 }
}

 

そして、「nuxt.config.js」にあるモジュールの項目に下記のように追記して、新たに「styleResources」の項目を追加し、その中に値として使いたい変数やmixinが含まれているSassファイルのパスを指定します。読み込み順を考慮する必要がある場合には、その順番に記述しましょう。

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

export default {
 modules: [
  '@nuxtjs/style-resources'
 ],
 styleResources: {
  sass: [
   '@/assets/sass/variable.sass'
  ],
  scss: [
   '@/assets/scss/_variable.scss',
   '@/assets/scss/_mixin.scss'
  ],
  stylus: [
   '@/assets/stylus/layout.styl'
  ]
 }
}

 

styleResourcesの値には対象となるSassファイルを指定しますが、拡張子の種類別に分けて書く必要があるので注意しましょう。これでグローバルのSassファイルにある変数やmixinもコンポーネントファイルで自由に使うことができます。他にもこのようなモジュールはあるようですが、サポートが終わっていたりと、新しいバージョンのNuxtプロジェクトで使えないといったことがあるので気をつけたいですね。

 

(参考にさせて頂いたサイト)
nuxt-community/style-resources-module

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

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

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

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

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

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

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

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

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

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

CAPTCHA


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