Vue CLIで共通のSCSSファイルを読み込む方法

リセットCSSフレームワークなどを使用したい場合は、yarnやnpmでインストールになりますが、今回は自分で.scssファイルを作成して、コンパイルして読み込ませる方法をまとめておきます(本来はVue.jsをせっかく使うなら、共通のCSSは使わない方がいいと言われていますが…)。
前提として、Vue CLIのセットアップ時に「CSS Pre-processors」で「Sass/SCSS」を選択している必要があります。
SCSSファイルの作成
SCSSファイルはどこに作成してもいいのですが、とりあえず下記のパスにフォルダとファイルを作成しておきます。
/src/assets/scss/style.scss作成ができたら読み込みをします。
共通のSCSSを読み込む方法
Vue CLIで共通のSCSSを読み込む方法は2つありますが、基本はmain.jsに記述を追加する方法のほうがラクそうです。
JavaScriptで読み込む方法
/src/main.jsに下記の1行を付け加えるだけです。
基本的に共通のSCSSを読み込みたい場合は、こちらの方法を使った方がよさそうです(記述も1行で済みます)。
require('@/src/assets/scss/style.scss')Vueコンポーネントで読み込む方法
vue.config.jsに下記の記述を追加するだけです。
module.exports = {
## ↑他の設定省略
css: {
loaderOptions: {
sass: {
data: `@import "./src/assets/scss/style.scss";`
}
},
},
## ↓他の設定省略
}module.exportsは最初から記述されているので、何も設定していない場合はcss:から記述をすればOKです。


全角スペースを可視化してくれるVisual Studio Codeの拡張機能「zenkaku」
さくらのレンタルサーバで.htaccessが原因で500エラーになってしまう場合のチェックリスト
WordPressのカスタム投稿タイプを追加後、ページは存在しているはずなのに404になる場合の解決方法
JavaScriptのtest関数と正規表現でバリデーションチェックを行う
.htaccessを使って、httpからhttpsへリダイレクトする設定方法
Visual Studio Codeで正規表現にマッチするか確認できる拡張機能「Regex Previewer」
Vue.jsでtemplateタグ内にscriptやstyleタグを生成する方法|Tags with side effect are ignored
Emmetで複数のタグを一括展開して、コーディングスピードをさらに上げる方法
Macで.pemを使ってAmazon EC2インスタンスへSSH接続する方法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
Path Finderを使ってキーボードだけでファイル操作する方法(応用編)
macOSのコマンドパレット比較!SpotlightとAlfred、Raycastどれを使えばいい?
1つのノートアプリにすべて集約するのをやめた理由|2025年時点のノートアプリの使い分け
Notionログイン時の「マジックリンク」「ログインコード」をやめて普通のパスワードを使う
AlfredでNotion内の検索ができるようになるワークフロー「Notion Search」
Gitで1行しか変更していないはずのに全行変更した判定になってしまう
Macでアプリごとに音量を調節できるアプリ「Background Music」
Macのターミナルでパスワード付きのZIPファイルを作成する方法
MacBook Proでディスプレイのサイズ調整をして作業スペースを広げる