OS: Windows10(64bit)、 Node.js v14.3.0、npm v6.14.5の環境で、Gulp v4.0.2を利用したコーディングをしています。
browser-syncを利用してコード(.scss)の変化を監視、オートリロードですぐに確認したい…のですが、下記のような
エラーが出てしまい、scssがコンパイルされません。
#####git-bashの内容
(略) Error in plugin "sass" Message: sass\style.scss Error: File to import not found or unreadable: ./module/base. on line 11 of sass/style.scss >> @import "./module/base"; ^ (略)
###実現したいこと
上記エラーを解消し、ライブリロードで仮想環境上の反映されたスタイルをすぐ確認できるようにしたいです。
browser-syncを使用しない場合は何事もなくコンパイルできるのですが、監視してライブリロードをするとなると
必ずこうなってしまいます。Node-sassが関連しているという記事を参考にしたり、海外のサイトも参考に
試してみるもうまく行かず…
一体何が原因なのかさっぱりわからず途方に暮れています。
package.json, gulpfile.js, style.scssの内容は以下の通りです。
#####package.json(あれこれ試した結果、余計なものも入ってます)
{ "name": "flowchart_test", "version": "1.0.0", "description": "for test flowchart.js", "main": "gulpfile.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1", "build": "gulp", "export": "NODE_ENV=production gulp export", "webpd": "webpack --mode development", "webpro": "webpack --display-used-exports --mode production", "webdev": "webpack --display-used-exports --mode development" }, "author": "szq0011", "license": "ISC", "devDependencies": { "@babel/cli": "^7.8.4", "@babel/core": "^7.9.6", "@babel/preset-env": "^7.9.6", "@types/jquery": "^3.3.38", "@types/node": "^14.0.1", "autoprefixer": "^9.8.0", "babel-loader": "^8.1.0", "browser-sync": "^2.26.7", "css-loader": "^3.5.3", "ejs-lint": "^1.1.0", "fancy-log": "^1.3.3", "gulp": "^4.0.2", "gulp-autoprefixer": "^7.0.1", "gulp-clean-css": "^4.3.0", "gulp-compass": "^2.1.0", "gulp-csscomb": "^3.1.0", "gulp-ejs": "^5.1.0", "gulp-if": "^3.0.0", "gulp-load-plugins": "^2.0.3", "gulp-plumber": "^1.2.1", "gulp-rename": "^2.0.0", "gulp-replace": "^1.0.0", "gulp-sass": "^4.1.0", "gulp-sass-glob": "^1.1.0", "gulp-sourcemaps": "^2.6.5", "imports-loader": "^0.8.0", "mini-css-extract-plugin": "^0.9.0", "node-sass": "^4.14.1", "postcss-loader": "^3.0.0", "sass-loader": "^8.0.2", "style-loader": "^1.2.1", "ts-loader": "^7.0.4", "typescript": "^3.9.2", "uglifyjs-webpack-plugin": "^2.2.0", "webpack": "^4.43.0", "webpack-cli": "^3.3.11", "webpack-stream": "^5.2.1" }, "dependencies": { "@babel/polyfill": "^7.8.7", "core-js": "^3.6.5", "jquery": "^3.5.1", "raphael": "^2.3.0", "swiper": "^5.4.0" } }
#####gulpfile.js
'use strict'; const fs = require('fs'); const {task, src, dest, watch, series, parallel} = require('gulp'); const autoPreFixer = require('gulp-autoprefixer'); const cleanCss = require('gulp-clean-css'); const cssComb = require('gulp-csscomb'); const ejs = require('gulp-ejs'); const gulpIf = require('gulp-if'); const plumber = require('gulp-plumber'); const rename = require('gulp-rename'); const replace = require('gulp-replace'); const sass = require('gulp-sass'); const sassGlob = require('gulp-sass-glob'); const sourceMaps = require('gulp-sourcemaps'); // develpment flag; switch 'true' or 'false'. true = development; const devMode = true; // browser const browser = require('browser-sync'); // style sass.compiler = require('node-sass'); const scss_src = './sass/**/*.scss'; // scssの場所 const css_dest = '../dist/css/'; // css出力場所 // js with webpack const webpack = require('webpack'); const webpackStream = require('webpack-stream'); let webpackConfig = require('./webpack.config'); const webpackMode = devMode? 'development' : 'production'; webpackConfig.mode = webpackMode; const js_dest = '../dist/js/'; // サーバー立ち上げ const browserSyncOption = { port: 8080, server: { baseDir: '../dist/', index: 'index.html', }, reloadOnRestart: true, }; function browsersync(done) { browser.init(browserSyncOption); done(); } function watchFiles(done) { const browserReload = () => { browser.reload(); done(); }; watch(['ejs/**/*',]).on('change', series(html, browserReload)); watch(['sass/**/*.scss',]).on('change', series(css, browserReload)); watch(['js/**/*',]).on('change', series(js, browserReload)); } // scssをコンパイルするタスク function css() { return src(scss_src) .pipe(plumber()) .pipe(gulpIf(devMode, sourceMaps.init())) .pipe(sassGlob()) .pipe(sass({ outputStyle: devMode? 'expanded' : 'compressed', outFile: '../dist/css/', }).on('error', sass.logError)) .pipe(gulpIf(devMode, sourceMaps.write())) .pipe(cssComb()) .pipe(autoPreFixer()) .pipe(gulpIf(!devMode, cleanCss())) // 圧縮 .pipe(dest(css_dest)) .pipe(browser.reload({stream: true})); }; // ejsをコンパイルするタスク function html(done) { const jsonFile = "./ejs/pages.json"; const jsonFile2 = "./ejs/contents.json"; const ejsSrc = "./ejs/*.ejs"; const json = JSON.parse(fs.readFileSync(jsonFile)); // JSON読み込み const json2 = JSON.parse(fs.readFileSync(jsonFile2)); const pages = json.pages; const contents = json2.contents; const result = []; for (var i = 0; i < pages.length; i++) { var id = pages[i].id; result.push(src(ejsSrc) .pipe(plumber()) .pipe(ejs({ jsonData: pages[i], // JSONのデータをejsに渡す contents: contents, // JSONのデータをejsに渡す devMode: devMode, })) .pipe(rename(id + '.html')) // (id).htmlにファイル名変更 .pipe(dest("../dist/")) .pipe(browser.reload({stream: true})) ); } done(); }; // js with webpack function js() { return src('./js/*.js') .pipe(plumber()) .pipe(webpackStream(webpackConfig, webpack)) .pipe(dest(js_dest)) .pipe(browser.reload({stream: true})); }; // default に設定タスクを登録 task('default', series(parallel(html, css, js), series(browsersync, watchFiles))); exports.html = html; exports.css = css; exports.js = js; exports.compile = series(html, css, js);
#####style.scss
@import "./mixin/mixin"; @import "./module/theme_head"; @import "./reset/ress"; @import "./config/config"; @import "./module/head"; @import "./module/base"; @import "./module/pc";
ファイル構成
dev ─┬─ webpack.config.js ├─ gulpfile.js ├─ package.json ├─ package-lock.js ├─ tsconfig.json ├─ webpack.config.js ├─ ejs ─── (略) ├─ js ─── (略) ├─ ts ─── (略) ├─ node_modules └─ sass ─┬─ style.scss ├─ config ─── _config.scss ├─ mixin ─── _mixin.scss ├─ module ─┬─ _base.scss │ ├─ _guide.scss │ ├─ _head.scss │ ├─ _lt.scss │ ├─ _pc.scss │ ├─ _sp.scss │ ├─ _tb.scss │ └─ _theme.head.scss ├─ reset ─┬─ _normalize.scss │ └─ _ress.scss └─ vender ─┬─ _swiper.min.scss └─ _swiper.scss dist ─┬─ js ├─ css └─ index.html
お知恵をお貸しいただけると幸いです。
何卒よろしくおねがいします。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/05/25 21:40