Gulp で出力先を一つ上の階層にしたい
解決済
回答 1
投稿
- 評価
- クリップ 0
- VIEW 4,336
Gulp 出力先を一つ上の階層にしたい
Gulp を使用して制作しています。
普通は開発と出力は分けて制作すると思いますが、
プロジェクトごとに Gulp をインストールしていると面倒なので
1つにまとめてやろうと考えてます。
開発ディレクトリ=公開ディレクトリのような感じにしてやろうという試み
現在のGulp-Renameとdestの指定
gulp.task('sass', function() {
gulp.src('src/**/sass/**/*.scss')
.pipe(plumber({
errorHandler: notify.onError('Error: <%= error.message %>')
}))
.pipe(frontnote())
.pipe(sourcemaps.init())
.pipe(sass({
outputStyle: 'expanded',
sourcemap: true
}))
.pipe(autoprefixer({
browsers: ['last 2 version'],
cascade: false
}))
.pipe(mmq())
.pipe(sourcemaps.write(''))
.pipe(rename(function(path) {
path.dirname += '/css';
}))
.pipe(gulp.dest('src/'))
.pipe(browser.reload({
stream: true
}))
});
作業ディレクトリ構造
src
├ Project1
│ └ sass
│ └ css ←ここに出力される
├ Project2
├ Project3
│ ├ sass
│ └ css ←この階層に出力したい
├ Project4
│
gulpfile.js
sass と css の階層を同じにしたい
同様に js も いちいち開発と出力の階層を分けたくない、
作業中にフォルダの行きかいが とてもだるいのでまるごと完結したい。
この方法であれば、Gulpfile.js で指定を分ければ、
プロジェクトごとの Gulpfile.js を作れば、1つの Gulp で完結できる?
と考えています。
gulp-rename を色々試してみたが…
上記の指定が個人的に限界でした。Node Javascript は初心者で全然理解出来ません。
.pipe(rename(function (path) {
if (path.extname) {
if (path.dirname === '.') {
path.dirname = '';
}
path.dirname = '';
}
}))
海外フォーラムでこのような指定を見かけましたが理解ができなかったです。
解決策等ありましたら、教えていただきたいです。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
0
現在のGulpの設定を下記のようにしてもダメでしょうか。
// before
.pipe(rename(function(path) {
path.dirname += '/css';
}))
// after
.pipe(rename(function(path) {
path.dirname += '/../css'; // 単純に今のパスに parentを追加しているだけ
}))
今現状が、「Project1/sass/css」 として出力されるのであれば、「Project1/sass/../css(=Project/css)」 にすれば、ご希望の階層にcssディレクトリが作られると思いました。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.13%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
2017/03/21 10:09
無事、ディレクトリの階層を上に移動させることが出来ました。
/../ と指定すれば フォルダが作成されないのですね、
dest は ** の指定をすると **フォルダが作成されてしまうので
.. も ..フォルダが作成されるとばかり考えて下りました。
本当にありがとうございました。