资讯专栏INFORMATION COLUMN

NodeJS+Express搭建个人博客-gulp自动化构建工具使用(二)

Yangder / 2455人阅读

摘要:自动化构建工具使用简言现在不管是做前端还是后端的,不可避免的是要跟打交道的而且这么容易开发难道我们不想自己随手写点什么这类比较前卫的框架早就深度集成了很多前端的东西现在,就让我们手动为也插上的翅膀吧。

gulp自动化构建工具使用 简言
现在不管是做前端还是后端的,不可避免的是要跟html打交道的;而且Node这么容易开发web;难道我们不想自己随手写点什么?Express这类比较前卫的框架;早就深度集成了很多前端的东西;现在,就让我们手动为thinkphp也插上gulp的翅膀吧。
构建 第一步

在自己的thinkphp项目根目录中创建 package.json;加上以下依赖

{
  "name": "baijunyao/thinkphp-bjyadmin",
  "version": "1.0.0",
  "description": "WebLSS博客",
  "main": "index.js",
  "scripts": {
    "test": "echo "Error: no test specified" && exit 1"
  },
  "keywords": [
    "WebLSS",
    "博客"
  ],
  "author": "baijunyao",
  "license": "Apache2",
  "devDependencies": {
    "babel-preset-es2015": "^6.18.0",
    "babel-preset-stage-2": "^6.18.0",
    "browser-sync": "^2.14.0",
    "gulp": "^3.9.1",
    "gulp-babel": "^6.1.2",
    "gulp-cleanhtml": "^1.0.1",
    "gulp-concat": "^2.6.0",
    "gulp-contrib-copy": "^0.1.2",
    "gulp-decomment": "^0.1.3",
    "gulp-imagemin": "^3.0.2",
    "gulp-less": "^3.1.0",
    "gulp-load-plugins": "^1.2.4",
    "gulp-minify-css": "^1.2.4",
    "gulp-plumber": "^1.1.0",
    "gulp-rename": "^1.2.2",
    "gulp-sass": "^2.3.2",
    "gulp-uglify": "^2.0.0"
  }
}
第二步

创建gulpfile.js文件

/**
 *  Created by WebLss on 2018/8/3
 */
var gulp = require("gulp")
var sass = require("gulp-sass")
var minifyCss = require("gulp-minify-css")
var plumber = require("gulp-plumber")
var babel = require("gulp-babel")
var uglify = require("gulp-uglify")
var clearnHtml = require("gulp-cleanhtml")
var imagemin = require("gulp-imagemin")
var copy = require("gulp-contrib-copy")
var browserSync = require("browser-sync").create()
var reload = browserSync.reload
// 定义源代码的目录和编译压缩后的目录
var src = "public/src"
var dist = "public/dist"
var viewSrc = "views/src"
var viewDist = "views/dist"
// 编译全部scss 并压缩
gulp.task("css", function () {
  gulp.src(src + "/**/*.scss")
    .pipe(sass())
    .pipe(minifyCss())
    .pipe(gulp.dest(dist))
})
// 编译全部js 并压缩
gulp.task("js", function () {
  gulp.src(src + "/**/*.js")
    .pipe(plumber())
    .pipe(babel({
      presets: ["es2015"]
    }))
    .pipe(uglify())
    .pipe(gulp.dest(dist))
})
// 压缩全部html
gulp.task("html", function () {
  gulp.src(src + "/**/*.+(html|ejs)")
    .pipe(clearnHtml())
    .pipe(gulp.dest(dist))
  // 编译视图文件
  gulp.src(viewSrc + "/**/*.+(html|ejs)")
    .pipe(clearnHtml())
    .pipe(gulp.dest(viewDist))
})
// 压缩全部image
gulp.task("image", function () {
  gulp.src([src + "/**/*.+(jpg|jpeg|png|gif|bmp)"])
    .pipe(imagemin())
    .pipe(gulp.dest(dist))
})
// 其他不编译的文件直接copy
gulp.task("copy", function () {
  gulp.src(src + "/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html|ejs)")
    .pipe(copy())
    .pipe(gulp.dest(dist))
})
// 自动刷新
gulp.task("server", function () {
  browserSync.init({
    proxy: "veekergdn.com", // 指定代理url
    notify: false // 刷新不弹出提示
  })
  // 监听scss文件编译
  gulp.watch(src + "/**/*.scss", ["css"])
  // 监听其他不编译的文件 有变化直接copy
  gulp.watch(src + "/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)", ["copy"])
  // 监听html文件变化后刷新页面
  gulp.watch(src + "/**/*.js", ["js"]).on("change", reload)
  // 监听html文件变化后刷新页面
  gulp.watch(src + "/**/*.+(html|ejs)", ["html"]).on("change", reload)
  // 监听css文件变化后刷新页面
  gulp.watch(dist + "/**/*.css").on("change", reload)
})
// 监听事件
gulp.task("default", ["css", "js", "image", "html", "copy", "server"])

把 gulpfile.js 中的src 和 dist 变量替换为自己项目的实际目录;
把proxy 替换为自己的本地自定义域名;
第三步: 命令行运行如下命令:

安装各种包

cnpm install 或npm install

运行gulp

gulp
如果不出意外;会自动编译并打开浏览器了;
很简单吧;就3步;
以项目为例讲解下吧: https://github.com/WebLss/Nod...
运行gulp后;会有如下操作;

1.src目录下的图片、文件、html、scss都会编译到view_dist目录
2.可以手动设置开发阶段使用src/dist目录的html页面,`product`和`development`
两个状态切换
3.触发监听任务,有文件变动自动执行上述几条任务,并且自动刷新浏览器,
这又是一个一次整合终身受益,不止是终身;换个项目同样可以很方便复用;
意义

估计大家也都看出来了,为什么要用gulp编译压缩,无非就是有效利用空间资源,优化加载速度,优化网站性能,提升用户体验感

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/19352.html

相关文章

  • NodeJS+Express搭建个人博客-环境搭建(一)

    摘要:本项目持续更新中,开源免费与各位爱好技术达人共勉,注现阶段仍在开发中。。。。。 NodeJS+Express+MongoDb开发的个人博客 NodeJS+Express搭建个人博客-环境搭建(一)NodeJS+Express搭建个人博客-gulp自动化构建工具使用(二)NodeJS+Express搭建个人博客-Express+Mongodb组合架构介绍(三)NodeJS+Express...

    Clect 评论0 收藏0
  • 个人博客主页搭建随笔

    摘要:博主目前的这个项目还不算很大,模块依赖简单,但期望完成诸如版本号替换,压缩代码,合并文件,发布到服务器等和模块化关系不大的工作,所以使用了。同时,对和附加缓存,配合和版本号实现服务器更新,这一部分其实已经帮我们实现好了。 经常在各种论坛、博客还有 github 上活跃的朋友不难发现,许多大牛都有自己的网站,也多以博客为主。博主作为一个立志前端的大白,难道不应该和大牛学习么?说干就干,前...

    whjin 评论0 收藏0
  • 个人博客主页搭建随笔

    摘要:博主目前的这个项目还不算很大,模块依赖简单,但期望完成诸如版本号替换,压缩代码,合并文件,发布到服务器等和模块化关系不大的工作,所以使用了。同时,对和附加缓存,配合和版本号实现服务器更新,这一部分其实已经帮我们实现好了。 经常在各种论坛、博客还有 github 上活跃的朋友不难发现,许多大牛都有自己的网站,也多以博客为主。博主作为一个立志前端的大白,难道不应该和大牛学习么?说干就干,前...

    cnio 评论0 收藏0
  • 全栈最后一公里 - Node.js 项目的线上服务器部署与发布

    摘要:没有耐心阅读的同学,可以直接前往学习全栈最后一公里。我下面会罗列一些,我自己录制过的一些项目,或者其他的我觉得可以按照这个路线继续深入学习的项目资源。 showImg(https://segmentfault.com/img/bVMlke?w=833&h=410); 本文技术软文,阅读需谨慎,长约 7000 字,通读需 5 分钟 大家好,我是 Scott,本文通过提供给大家学习的方法,...

    Nosee 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<