0%

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

Posted:2017.03.04

gulpをローカルにインストールしてプロジェクト内で使用する

クライアント側でのコーディングは近年複雑になってきており、それに伴っていろんな作業が増えてきています。そこで少しでも作業時間を短縮するために、gulpというタスクランナーツールを使うことで効率よくコーディングを行うことが可能になります。今回は実際にプロジェクトで導入するフローをまとめていきたいと思います。

 

gulpをローカルへインストールする

まずは事前準備としてグローバルにgulpをインストールしておきます。下記のコマンドを入力します。詳しくは過去の記事「WEB開発環境(Mac OS)に必要な各種インストール方法まとめ(1)」をご参考に。

 

$ sudo npm install gulp -g

 

次にローカルにgulpをインストールを行うので、コマンドでプロジェクトフォルダまで移動します。プロジェクトフォルダに移動したらコマンドでgulpをローカルにインストールします。

 

$ cd プロジェクトフォルダ名 // プロジェクトフォルダまで移動する
$ npm install --save-dev gulp

 

インストールが終わると「node_modules」フォルダが生成されますので、下記コマンドでインストールが完了しているかを確認します。

 

$ gulp -v // CLIとLocalのバージョンが表示されればOK

 

インストールが完了したら「package.json」ファイルを用意します。これは必要なパッケージを記録しておくためのファイルです。プロジェクトフォルダのnode_modulesと同じ階層で下記のコマンドを入力すると自動的に生成されます。

 

$ npm init -y

 

次に下記の内容を記述したgulpfile.jsのjavascriptファイルを作成し、node_modulesフォルダ、package.jsonファイルと同じ階層に配置します。

 

【gulpfile.js】

var gulp = require("gulp");

 

これでローカルでgulpの準備が整いました。

 

便利なgulpのプラグインを追加する

gulpにはいろんなプラグインが用意されており、それらを使うことでより効率的にコーディングを進めていくことが可能になります。ここではよく使うものをいくつかピックアップしていきたいと思います。それぞれコマンドを入力してインストールします。

 

// CSS圧縮
$ npm install gulp-cssmin --save-dev

// javascript圧縮
$ npm install gulp-uglify --save-dev

// 画像圧縮
$ npm install gulp-imagemin --save-dev

// Sassコンパイル
$ npm install gulp-sass --save-dev

// ファイル名リネーム
$ npm install gulp-remame --save-dev

 

gulpへタスクを登録する

プラグインをインストールしたら、それぞれに対応したタスクをgulpfile.jsへコードで追記していき実行できるタスクを追加します。

 

【gulpfile.js】

//【cssmin】css圧縮・ファイル名に.min追加
var cssmin = require("gulp-cssmin");
var rename = require("gulp-rename");
gulp.task("cssmin", function () {
  gulp.src("css/*.css")
        .pipe(cssmin())
    .pipe(rename({suffix: '.min'}))
    .pipe(gulp.dest('./css/min'));
});

//【uglify】javascript圧縮・ファイル名に.min追加
var uglify = require("gulp-uglify");
var rename = require("gulp-rename");
gulp.task("jsmin", function() {
    gulp.src(["js/**/*.js","!js/**/*.min.js"])
        .pipe(uglify())
        .pipe(rename({
            extname: '.min.js'
        }))
        .pipe(gulp.dest("./js/min"));
});

//【image】PNG画像圧縮
var image = require("gulp-image");
gulp.task("image", function() { 
    gulp.src("img/*.png")    
      .pipe(image())   
      .pipe(rename({
          extname: '.min.png'
        }))
      .pipe(gulp.dest("img/"));   
});

//【sass】Sass(scssファイル)コンパイル
var sass = require("gulp-sass");
gulp.task("sass", function() {
  gulp.src("scss/**/*.scss")
    .pipe(sass())
    .pipe(gulp.dest("./css"));
});

 

これらのコードを追記するとそれぞれ以下のコマンドでタスクを実行できるようになります。

 

$ gulp cssmin // CSS圧縮のタスクを実行
$ gulp jsmin // javascript圧縮のタスクを実行
$ gulp image // PNG画像圧縮のタスクを実行
$ gulp sass // sassファイルコンパイルのタスクを実行

 

 

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

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

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

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

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

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

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

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

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

CAPTCHA


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