{"id":1971,"date":"2017-07-07T09:57:47","date_gmt":"2017-07-07T00:57:47","guid":{"rendered":"http:\/\/alaki.co.jp\/blog\/?p=1971"},"modified":"2017-07-07T09:58:54","modified_gmt":"2017-07-07T00:58:54","slug":"%e4%bd%9c%e6%a5%ad%e6%99%82%e9%96%93%e3%82%9220%e7%9f%ad%e7%b8%ae%ef%bc%81gulp%e3%81%ae%e4%be%bf%e5%88%a9%e3%81%aa%e3%83%97%e3%83%a9%e3%82%b0%e3%82%a4%e3%83%b3%e3%83%bb%e3%82%bf%e3%82%b9%e3%82%af","status":"publish","type":"post","link":"http:\/\/test.alaki.co.jp\/blog\/?p=1971","title":{"rendered":"\u4f5c\u696d\u6642\u9593\u309220%\u77ed\u7e2e\uff01gulp\u306e\u4fbf\u5229\u306a\u30d7\u30e9\u30b0\u30a4\u30f3\u30fb\u30bf\u30b9\u30af\u307e\u3068\u3081"},"content":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f\uff01<\/p>\n<p>\u30c7\u30b6\u30a4\u30ca\u30fc\u306e\u4f0a\u6771\u3067\u3059\u3002<br \/>\n\u524d\u56de\u3001\u524d\u3005\u56de\u3068\u30c7\u30b6\u30a4\u30f3\u306e\u6982\u5ff5\u7684\u306a\u90e8\u5206\u3092\u8a18\u4e8b\u306e\u984c\u6750\u3068\u3057\u3066\u3044\u307e\u3057\u305f\u304c\u3001\u3053\u3053\u3089\u8fba\u3067\u6280\u8853\u7684\u306a\u304a\u8a71\u3001\u305d\u308c\u3082\u30c7\u30b6\u30a4\u30f3\u3067\u306f\u306a\u304f\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u3053\u3068\u306b\u3064\u3044\u3066\u66f8\u3053\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u6700\u8fd1\u3001\u696d\u52d9\u3067gulp\u3092\u983b\u7e41\u306b\u4f7f\u7528\u3059\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<br \/>\ngulp\u3068\u306f\u3001\u753b\u50cf\u306e\u5727\u7e2e\u3084sass\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u3001ftp\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306a\u3069\u306e\u7d30\u3005\u3057\u305f\u4f5c\u696d\u3092\u81ea\u52d5\u5316\u3057\u3066\u304f\u308c\u308b\u3001\u30bf\u30b9\u30af\u30e9\u30f3\u30ca\u30fc\u3068\u547c\u3070\u308c\u308b\u3082\u306e\u306e\u4e00\u3064\u3067\u3059\u3002gulp\u306e\u4ed6\u306b\u306fGrunt\u306a\u3093\u304b\u3082\u3088\u304f\u8033\u306b\u3057\u307e\u3059\u3002<\/p>\n<p>\u4ee5\u524d\u304b\u3089\u5b58\u5728\u3092\u77e5\u3063\u3066\u306f\u3044\u305f\u3082\u306e\u306e\u306a\u304b\u306a\u304b\u624b\u3092\u3064\u3051\u305a\u306b\u3044\u307e\u3057\u305f\u304c\u3001\u4e00\u65e6\u4f7f\u3063\u3066\u307f\u308b\u3068\u305d\u306e\u4fbf\u5229\u3055\u306b\u4ee5\u524d\u306e\u4f5c\u696d\u74b0\u5883\u304c\u3060\u3044\u3076\u4e0d\u4fbf\u306b\u611f\u3058\u307e\u3059\u3002<br \/>\n\u307e\u3060\u307e\u3060\u8a66\u3057\u3066\u3044\u306a\u3044\u6a5f\u80fd\u3082\u305f\u304f\u3055\u3093\u3042\u308a\u307e\u3059\u304c\u3001\u4eca\u56de\u306fgulp\u306e\u4fbf\u5229\u306a\u30d7\u30e9\u30b0\u30a4\u30f3\u30fb\u30bf\u30b9\u30af\u3092\u307e\u3068\u3081\u3066\u307f\u307e\u3057\u305f\u306e\u3067\u3054\u89a7\u304f\u3060\u3055\u3044\u3002<\/p>\n<p><!--more--><\/p>\n<h2>\u30d6\u30e9\u30a6\u30b6\u3092\u81ea\u52d5\u3067\u30ea\u30ed\u30fc\u30c9\uff01\u3000[browser-sync]<\/h2>\n<p>\u30a8\u30c7\u30a3\u30bf\u3067\u30d5\u30a1\u30a4\u30eb\u3092\u4fdd\u5b58\u3057\u3066\u3001\u30d6\u30e9\u30a6\u30b6\u306b\u79fb\u52d5\u3057\u3066\u3001\u30ea\u30ed\u30fc\u30c9\u3057\u3066\u3001\u3001\u3001<br \/>\n\u3053\u308c\u3060\u3051\u30672,3\u79d2\u304b\u304b\u3063\u3066\u3044\u305f\u4f5c\u696d\u304c\u3001browser-sync\u306a\u3089\u4e00\u77ac\u3067\u3059\u3002<br \/>\nhtml\u3067\u3082css\u3067\u3082\u3001\u4fdd\u5b58\u3057\u305f\u77ac\u9593\u306b\u30d6\u30e9\u30a6\u30b6\u3092\u52dd\u624b\u306b\u30ea\u30ed\u30fc\u30c9\u3057\u3066\u304f\u308c\u307e\u3059\u3002<br \/>\n\u305f\u3063\u305f\u305d\u308c\u3060\u3051\u306e\u3053\u3068\u3067\u3059\u304c\u3001\u5b9f\u969b\u306b\u4f7f\u3063\u3066\u307f\u308b\u3068\u9a5a\u304f\u307b\u3069\u5feb\u9069\u3067\u3059\u3002<\/p>\n<p>gulp\u3067\u306f\u3001\u3053\u306ebrowser-sync\u3082\u30bf\u30b9\u30af\u3068\u3057\u3066\u76e3\u8996\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\">npm install -g browser-sync<\/pre>\n<pre class=\"lang:js decode:true\" title=\"\u30b3\u30fc\u30c9\">var gulp = require('gulp');\r\nvar browserSync =require('browser-sync');\r\n\r\ngulp.task('default', ['browser-sync']);\r\n\r\n\r\ngulp.task('browser-sync', function() {\r\n    browserSync({\r\n        server: {\r\n             baseDir: \".\/htdocs\/\"       \/\/\u5bfe\u8c61\u3068\u306a\u308b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\r\n            ,index  : \"index.html\"      \/\/\u30a4\u30f3\u30c7\u30c3\u30af\u30b9\u30d5\u30a1\u30a4\u30eb\r\n        }\r\n    });\r\n});\r\n\r\n\/\/\r\n\/\/\u30d6\u30e9\u30a6\u30b6\u30ea\u30ed\u30fc\u30c9\r\n\/\/\r\ngulp.task('bs-reload', function () {\r\n    browserSync.reload();\r\n});\r\n\r\n\/\/\r\n\/\/\u76e3\u8996\u3059\u308b\u30d5\u30a1\u30a4\u30eb\r\n\/\/\r\ngulp.task('default', ['browser-sync'], function () {\r\n    gulp.watch(\".\/htdocs\/*.html\",            ['bs-reload']);\r\n    gulp.watch(\".\/htdocs\/src\/css\/*.css\", ['bs-reload']);\r\n    gulp.watch(\".\/htdocs\/src\/js\/*.js\",   ['bs-reload']);\r\n});<\/pre>\n<p>&nbsp;<\/p>\n<h2>\u7206\u901f\u3067sass\u3092\u30b3\u30f3\u30d1\u30a4\u30eb\uff01\u3000[gulp-sass]<\/h2>\n<p>sass\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u3092gulp\u3067\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br \/>\ngulp\u3092\u4f7f\u3046\u524d\u306fcompass\u3067\u30b3\u30f3\u30d1\u30a4\u30eb\u3057\u3066\u3044\u307e\u3057\u305f\u304c\u3001\u30b3\u30f3\u30d1\u30a4\u30eb\u306b\u304b\u304b\u308b\u6642\u9593\u304c\u4f53\u611f\u7684\u306b\u3060\u3044\u3076\u65e9\u304f\u306a\u3063\u305f\u306e\u3092\u611f\u3058\u3066\u3044\u307e\u3059\u3002<br \/>\ncompass\u3067\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u306f2\u79d2\u7a0b\b\u5f85\u3061\u6642\u9593\u304c\u3042\u308a\u307e\u3057\u305f\u304c\u3001gulp-sass\u3067\u306f1\u79d2\u3082\u304b\u304b\u3063\u3066\u3044\u307e\u305b\u3093\u3002\u5c0f\u3055\u3044\u5dee\u306b\u601d\u308f\u308c\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u304c\u3001\u7a4d\u307f\u91cd\u306d\u3066\u3044\u304f\u3068\u5927\u304d\u306a\u4f5c\u696d\u6642\u9593\u77ed\u7e2e\u306b\u3064\u306a\u304c\u308a\u307e\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\">npm install gulp-sass --save-dev<\/pre>\n<pre class=\"lang:js decode:true\" title=\"\u30b3\u30fc\u30c9\">var gulp = require('gulp');\r\nvar sass = require('gulp-sass');\r\n\r\n\/\/ \u4fdd\u5b58\u5148\u306e\u6307\u5b9a\r\ngulp.task('sass', function(){\r\n  gulp.src('.\/sass\/**\/*.scss')\r\n    .pipe(sass({outputStyle: 'expanded'}))\r\n    .pipe(gulp.dest('.\/css\/'));\r\n});\r\n\r\n\/\/\u81ea\u52d5\u76e3\u8996\u306e\u30bf\u30b9\u30af\r\ngulp.task('sass-watch', ['sass'], function()\r\n  var watcher = gulp.watch('.\/sass\/**\/*.scss', ['sass']);\r\n  watcher.on('change', function(event) {\r\n  });\r\n});\r\n\r\ngulp.task('default', ['sass-watch']);<\/pre>\n<p>&nbsp;<\/p>\n<h2>\u30b3\u30de\u30f3\u30c9\u4e00\u3064\u3067CSS\u306elint\u30c1\u30a7\u30c3\u30af\uff01\u3000[gulp-csslint]<\/h2>\n<p>css\u3092lint\u30c1\u30a7\u30c3\u30af\u306b\u304b\u3051\u308b\u3053\u3068\u3082gulp\u3067\u306f\u53ef\u80fd\u3067\u3059\u3002<br \/>\n\u3044\u3061\u3044\u3061lint\u306e\u30b5\u30a4\u30c8\u306b\u79fb\u52d5\u3057\u3066\u3001url\u3092\u5165\u529b\u3059\u308b\u624b\u9593\u3082\u5fc5\u8981\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\">npm install --save-dev gulp-csslint<\/pre>\n<pre class=\"lang:js decode:true\" title=\"\u30b3\u30fc\u30c9\">var csslint = require('gulp-csslint');\r\ngulp.task('css', function() {\r\n\tgulp.src('css\/*.css')\r\n\t\t.pipe(csslint())\r\n\t\t.pipe(csslint.reporter());\r\n});<\/pre>\n<p>&nbsp;<\/p>\n<h2>\u30d9\u30f3\u30c0\u30fc\u30d7\u30ec\u30d5\u30a3\u30c3\u30af\u30b9\u3092\u81ea\u52d5\u4ed8\u4e0e\uff01\u3000[gulp-autoprefixer]<\/h2>\n<p>\u30d7\u30ed\u30d1\u30c6\u30a3\u3054\u3068\u306b\u30b5\u30dd\u30fc\u30c8\u304c\u307e\u3061\u307e\u3061\u3067\u3001\u78ba\u8a8d\u3059\u308b\u306e\u3082\u9762\u5012\u306a\u30d9\u30f3\u30c0\u30fc\u30d7\u30ec\u30d5\u30a3\u30c3\u30af\u30b9\u3092\u3001\u81ea\u52d5\u3067\u3064\u3051\u3066\u304f\u308c\u308b\u512a\u308c\u3082\u306e\u3067\u3059\u3002<br \/>\n\u3064\u3051\u5fd8\u308c\u306b\u3088\u308b\u8868\u793a\u5d29\u308c\u306a\u3069\u3082\u672a\u7136\u306b\u9632\u3052\u308b\u306e\u3082\u9b45\u529b\u3067\u3059\u306d\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\">npm install -D gulp-autoprefixer<\/pre>\n<pre class=\"lang:js decode:true\" title=\"\u30b3\u30fc\u30c9\">var gulp = require('gulp');\r\nvar autoprefixer = require('gulp-autoprefixer');\r\n\r\ngulp.task('compile-css', function () {\r\n    return gulp.src(['src\/css\/*.css'])\r\n        .pipe(autoprefixer({\r\n            browsers: ['last 2 version', 'iOS &gt;= 8.1', 'Android &gt;= 4.4'],\r\n            cascade: false\r\n        }))\r\n        .pipe(gulp.dest('static\/css'));\r\n});<\/pre>\n<p>&nbsp;<\/p>\n<h2>\u81ea\u52d5\u3067\u753b\u50cf\u5727\u7e2e\uff01\u3000[gulp-imagemin]<\/h2>\n<p>Google\u306e\u30b5\u30a4\u30c8\u30b9\u30d4\u30fc\u30c9\u8a08\u6e2c\u30c4\u30fc\u30eb<a href=\"https:\/\/developers.google.com\/speed\/pagespeed\/insights\/\">PageSpeed Insights<\/a>\u3067\u8868\u793a\u901f\u5ea6\u3092\u8a08\u308b\u3068\u3001\u5927\u62b5\u6307\u6458\u3055\u308c\u308b\u306e\u304c\u753b\u50cf\u30b5\u30a4\u30ba\u306e\u6700\u9069\u5316\u3002<br \/>\n\u3061\u307e\u3061\u307e\u753b\u50cf\u306b\u5727\u7e2e\u3092\u304b\u3051\u308b\u306e\u306f\u9762\u5012\u3067\u3059\u304c\u3001imagemin\u3092\u4f7f\u7528\u3059\u308c\u3070\u81ea\u52d5\u3067\u753b\u50cf\u3092\u5727\u7e2e\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\" title=\"\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\">npm install --save-dev gulp-imagemin<\/pre>\n<pre class=\"lang:js decode:true \" title=\"\u30b3\u30fc\u30c9\">gulp.task('imagemin', function(){\r\n  return gulp.src('src\/images\/*')\r\n    .pipe(imagemin(\r\n      [\r\n        pngquant()\r\n      ],\r\n      {\r\n        interlaced: true,\r\n        progressive: true,\r\n        optimizationLevel: 5\r\n      }\r\n     ))\r\n     .pipe(gulp.dest('dist\/images'));\r\n});<\/pre>\n<p>&nbsp;<\/p>\n<p>\u4ee5\u4e0a5\u3064\u306e\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u3054\u7d39\u4ecb\u3057\u307e\u3057\u305f\u3002<br \/>\n\u307e\u3060\u307e\u3060gulp\u3092\u4f7f\u3044\u59cb\u3081\u305f\u3070\u304b\u308a\u3067\u3001\u8a66\u3057\u3066\u3044\u306a\u3044\u30d7\u30e9\u30b0\u30a4\u30f3\u3082\u305f\u304f\u3055\u3093\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u4eca\u5f8c\u4fbf\u5229\u306a\u3082\u306e\u3092\u898b\u3064\u3051\u305f\u3089\u3001\u307e\u305f\u3054\u7d39\u4ecb\u3057\u307e\u3059\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f\uff01 \u30c7\u30b6\u30a4\u30ca\u30fc\u306e\u4f0a\u6771\u3067\u3059\u3002 \u524d\u56de\u3001\u524d\u3005\u56de\u3068\u30c7\u30b6\u30a4\u30f3\u306e\u6982\u5ff5\u7684&#46;&#46;&#46;<\/p>\n","protected":false},"author":8,"featured_media":1978,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[26],"tags":[],"aioseo_notices":[],"_links":{"self":[{"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1971"}],"collection":[{"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/users\/8"}],"replies":[{"embeddable":true,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1971"}],"version-history":[{"count":9,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1971\/revisions"}],"predecessor-version":[{"id":1983,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1971\/revisions\/1983"}],"wp:featuredmedia":[{"embeddable":true,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=\/wp\/v2\/media\/1978"}],"wp:attachment":[{"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1971"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1971"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/test.alaki.co.jp\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1971"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}