構建工具爲Gulp
基於PostCSS
PostCSS插件 CSSNext 用下一代CSS書寫方式兼容如今瀏覽器
PostCSS插件 Autoprefixer 爲CSS補全瀏覽器前綴
PostCSS插件 CSS Grace 讓CSS兼容舊版IEjavascript
"devDependencies": { "autoprefixer": "^7.1.1", "browser-sync": "^2.18.8", "compass": "^0.1.1", "gulp": "^3.9.1", "gulp-changed": "^2.0.0", "gulp-compass": "^2.1.0", "gulp-html-beautify": "^1.0.1", "gulp-load-plugins": "^1.5.0", "gulp-plumber": "^1.1.0", "gulp-postcss": "^7.0.0", "gulp-pug": "^3.3.0", "gulp-sass": "^3.1.0", "gulp-sourcemaps": "^2.6.0", "precss": "^1.4.0", "pug": "^2.0.0-beta.12", "cssgrace": "^3.0.0" }, "dependencies": { "express": "^4.15.2", "pug": "^2.0.0-beta.12" }
var gulp = require("gulp"); var plugins = require("gulp-load-plugins")(); var browserSync = require("browser-sync").create(); var postcss = require('gulp-postcss'); var sourcemaps = require('gulp-sourcemaps'); var cssgrace = require('cssgrace'); // /*執行命令行工具*/ // var exec = require('child_process').exec; // exec("node server/index.js", function(err, stdout, stderr) { // var status = err ? -1 : 1, // cmd_result = err ? stderr : stdout; // // 能夠獲取到錯誤信息、標準輸出和標準錯誤輸出,接下來繼續處理吧 // }); //編譯pug gulp.task("pug:compile",function() { gulp.src("src/*.pug") .pipe(plugins.plumber()) .pipe(plugins.changed("./build/",{extension:".html"})) .pipe(plugins.pug({ pretty:"\t" })) .pipe(plugins.htmlBeautify({ indent_size:4, indent_char:" " })) .pipe(gulp.dest("./build/")) }) //監控pug gulp.task("pug:watch",function() { gulp.watch("src/*.pug",["pug:compile"]) }) //編譯pug-templates gulp.task('pug-templates:compile',function(){ gulp.src('src/*.pug') .pipe(plugins.plumber()) .pipe(plugins.pug({ pretty: '\t' })) .pipe(plugins.htmlBeautify({ indent_size: 4, indent_char: ' ', unformatted: true, extra_liners: [] })) .pipe(gulp.dest('./build/')); }); //監控pug-templates gulp.task('pug-templates:watch',function(){ gulp.watch('src/templates/*.pug',['pug-templates:compile']); }); /*編譯compass*/ gulp.task("compass:compile",function() { gulp.src("src/sass/sass_parts/*.scss") .pipe(plugins.plumber()) .pipe(plugins.compass({ config_file:"./src/sass/config.rb", sass:"src/sass/sass_parts", css:"src/sass/stylesheets" })) .pipe(sourcemaps.init()) .pipe( postcss([ require('precss'), require('autoprefixer'), cssgrace ]) ) .pipe( sourcemaps.write('.') ) .pipe(gulp.dest("./build/css")); }) //監控compass sass gulp.task("compass:watch",function() { gulp.watch("src/sass/sass_parts/**/*.scss",["compass:compile"]); }); //browser-sync gulp.task("browser-sync",function() { var files = [ "./build/*.html", "./build/**/*.css", "./build/**/*.js" ]; browserSync.init(files,{ server:{ baseDir:"./build" }, port:3061 }) }) gulp.task("default",["pug:watch","pug-templates:watch","compass:watch","browser-sync"])