XAMPPのuserdirで設定したサイトの作業更新をGulpのBrowsersyncで自動で確認する

技術情報

以前、XAMPPのuserdirによるローカルでの開発環境の構築、ローカルにあるCMSへのGulpの導入などをご紹介いたしました。

XAMPPのユーザーディレクトリの設定をしてWordPressをローカルで構築する
日本語 — WordPress 前回、XAMPPのユーザーディレクトリの設定をしてMovable Typeをローカルで構築する方法をご紹介いたしました。 今回、XAMPPのあたりは前回と同じなので、既知の方は読み飛ばしていただいてかまいませ...
Windowsに「Node.js」 と「Gulp.js」をインストールして、WordPressテーマのSimplicityの子テーマにあるCSSをMinify化して読み込んでみた
「Gulp」というタスクランナーが以前から気になっていたので、当サイトで採用しているWordPressテーマのSimplicityで適用してみることにしました。 今回は「Gulp」でCSSのMinify化(圧縮)を行ってみたのでご紹介いたし...

今回はXAMPPのuserdirで設定したサイトの作業更新を、GulpのBrowsersyncによって自動で起動、または更新する方法をご紹介いたします。

Gulpfile.js

Browsersyncを行うために作業フォルダで「npm i -D browser-sync」と入力して、プラグインをインストールしておきます。

npm i -D browser-sync

次に下記のような「Gulpfile.js」ファイルでsassやjsをwatchで監視しているとします。「リアルタイム監視」に記述している「browserSync.init」の「files」で監視しているファイルに変更があった場合、「proxy」でXAMPPのuserdirで設定した「localhost」のサイトを自動で起動、または更新をするようにします。

//gulpfile.js
/*-------------------- plug-in -------------------------------- */
//plug-in
var gulp = require('gulp');
var uglify = require('gulp-uglify');
var sass = require('gulp-sass');
var postcss = require('gulp-postcss');
var cssnext = require('postcss-cssnext');
var browserSync = require('browser-sync');
var reload = browserSync.reload;
/*-------------------- plug-in --------------------------------- */

/*-------------------- タスク ---------------------------------- */
var paths = {
    'scss': 'src/scss/',
    'css': 'dist/css/'
}

gulp.task('scss', function() {
  var processors = [
     cssnext({browsers: ["last 2 versions", "ie >= 9", "Android >= 4","ios_saf >= 8"]})
 ];
  return gulp.src(paths.scss + '**/*.scss')
    .pipe(postcss(processors))
    .pipe(sass({outputStyle: 'compressed'}))
    .pipe(gulp.dest(paths.css))
});

gulp.task('uglify', function() {
    return gulp.src("src/js/*.js")
    .pipe(uglify())
    .pipe(gulp.dest('dist/js/'))
});
/*-------------------- /タスク ------------------------------- */

/*-------------------- リアルタイム監視 ------------------------ */
gulp.task('watch', function() {
    gulp.watch('src/scss/*.scss', ['scss']);
    gulp.watch('src/js/*.js', ['uglify']);
    browserSync.init({
        files: ['src/scss/','src/js/'],
        proxy: 'http://localhost/~project-name'
    });
});
/*-------------------- /リアルタイム監視 ---------------------- */

「localhost」の部分を毎回IPアドレスに変えるのが面倒な場合は、「open:’external’」というBrowserSyncのオプションを追加して対応します。

/*-------------------- リアルタイム監視------------------------ */
gulp.task('watch', function() {
    gulp.watch('src/scss/*.scss', ['scss']);
    gulp.watch('src/js/*.js', ['uglify']);
    browserSync.init({
        files: ['src/scss/','src/js/'],
        proxy: 'http://localhost/~project-name',
        open: 'external' //「open: 'external'」オプション
    });
});
/*-------------------- /リアルタイム監視 ---------------------- */

Browsersyncの確認

作業するフォルダで「gulp watch」と入力して、監視を行います。

Browsersync 「gulp watch」で監視
「gulp watch」で監視

この時「proxy」で指定しているURLで、ローカルのサイトが自動で起動すればBrowsersyncは成功です。

PCのアドレス

起動したブラウザのアドレスを見てみると、「proxy」で設定した「localhost」の後に3000番台の数字が表示され、さらにその後がプロジェクト(サイト)のフォルダ名となります。

Browsersync 「localhost:3000番台/プロジェクトのフォルダ名」
「localhost:3000番台/~プロジェクトのフォルダ名」

「browserSync.init」に「open: ‘external’」を記述した場合は、「localhost」の部分がIPv4のアドレスに書き換わります。

Browsersync 「localhost」の部分がIPv4のアドレスに書き換る
「localhost」の部分がIPv4のアドレスに書き換る

これはコマンドラインで「ipconfig」を入力した値と同じIPになります。

Browsersync 「ipconfig」を入力した値と同じIP
「ipconfig」を入力した値と同じIP

モバイルのアドレス

同一ネットワーク上にある条件で、スマホなどの端末でもBrowsersyncで同期し、自動更新を行うことができます。アドレスバーで「localhost」の部分をIPv4のアドレスに変更します。

Browsersync 「http://IPv4:3000番台/~プロジェクトのフォルダ名」
「http://IPv4:3000番台/~プロジェクトのフォルダ名」

例として上記のパスは「http://IPv4:3000番台/~プロジェクトのフォルダ名」となります。

ブラウザで確認

監視しているファイルが変更され、保存された瞬間にブラウザがリロードされます。

画像をクリックすると動画が表示されます。
Browsersync 監視しているファイルが変更されるとブラウザがリロードされる
監視しているファイルが変更されるとブラウザがリロードされる

セキュリティソフトが原因でモバイルの確認(同期)ができない場合

セキュリティソフトで個人ネットワークが保護されている場合、モバイルのアドレスバーに入力しても確認ができない場合があります。その場合はセキュリティソフトの設定を行い、パーソナルネットワークの制限を変更する必要があります。ESETセキュリティソフトになりますが、下記に制限されているネットワークの変更方法を記載します。

ESET 設定を選択
「設定」を選択

「ネットワーク保護」を選択します。

ESET 「ネットワーク保護」を選択
「ネットワーク保護」を選択

「パーソナルファイアウォール」のアイコンから「設定」を選択します。

ESET 「パーソナルファイアウォール」のアイコンから「設定」を選択
「パーソナルファイアウォール」のアイコンから「設定」を選択

詳細設定の「パーソナルファイアウォール」からルールの「編集」をクリックします。

ESET 「パーソナルファイアウォール」からルールの「編集」をクリック
「パーソナルファイアウォール」からルールの「編集」をクリック

「ファイアウォールルール」の「追加」をクリックします。

ESET 「ファイアウォールルール」の「追加」をクリック
「ファイアウォールルール」の「追加」をクリック

「ルールの編集」から下記の設定を行います。

ESET 「ルールの編集」から設定を行う
「ルールの編集」から設定を行う
  1. 「一般」タブをクリック。
  2. 名前:任意の名称を入力。
  3. 有効:有効にチェック。
  4. 方向:双方向を選択。
  5. アクション:許可を選択。
  6. プロトコル:TCPを選択。
  7. プロファイル:任意のプロファイルを選択。
  8. 「OK」をクリック。

上記の設定で、同一のネットワークにあるモバイルの表示を確認することができます。

まとめ

  • 作業フォルダで「npm i -D browser-sync」を入力して、プラグインをインストールする。
  • 「Gulpfile.js」の「browserSync.init」でファイルを監視。
  • 「proxy」でXAMPPのuserdirで設定した「localhost」のサイトを指定。
  • 「localhost」の部分を毎回IPアドレスに変えるのが面倒な場合は「browserSync.init」に「open:’external’」を記述。
  • モバイルで確認する場合は「localhost」をPCの「IPv4」に変える。
  • セキュリティソフトが原因でモバイルの同期が出来ない場合は設定を変更する。

GulpのBrowsersyncができれば、HTMLやCSS、JSなど監視するファイルの変更があった時に、変更された状態でブラウザを自動でリロードできるので非常に便利です。確認するブラウザが多ければ多いほど、Browsersyncの有用性は高まるので、ぜひ活用しましょう。

スポンサーリンク
技術情報
スポンサーリンク
シェアする
ボヘミアンをフォローする
この記事が気に入ったら
いいね!しよう
最新情報をお届けします。
スポンサーリンク
PC ウェブログ

コメント