全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

nodejs前端自动化构建环境的搭建

为了UED前端团队更好的协作开发同时提高项目编码质量,我们需要将Web前端使用工程化方式构建;

目前需要一些简单的功能:

    1. 版本控制
    2. 检查JS
    3. 图片合并
    4. 压缩CSS
    5. 压缩JS
    6. 编译SASS

这些都是每个Web项目在构建、开发阶段需要做的事情。前端自动化构建环境可以把这些重复工作一次配置,多次重复执行,极大的提高开发效率。

目前最知名的构建工具: Gulp、Grunt、NPM + Webpack;
    grunt是前端工程化的先驱

    gulp更自然基于流的方式连接任务

    Webpack最年轻,擅长用于依赖管理,配置稍较复杂

    推荐使用Gulp,Gulp基于nodejs中stream,效率更好语法更自然,不需要编写复杂的配置文件

Use Gulp to automate front-end build tasks

Gulp是基于 Node.js的,需要要安装 Node.js

1、为了确保依赖环境正确,我们先执行几个简单的命令检查。
    node -v
    Node是一个基于Chrome JavaScript V8引擎建立的一个解释器
    检测Node是否已经安装,如果正确安装的话你会看到所安装的Node的版本号

2、接下来看看npm,它是 node 的包管理工具,可以利用它安装 gulp 所需的包
    npm -v
    这同样能得到npm的版本号,装 Node 时已经自动安装了npm

3、开始安装Gulp

    npm install -g gulp

    全局安装 gulp

    gulp -v

    得到gulp的版本号,确认安装成功

基础安装结束
-

4、切换到你的在项目根文件夹下,运行

    npm install gulp --save-dev //将具体的gulp功能插件局部安装项目下

5、安装gulp功能插件依赖包

    npm install gulp-jshint gulp-sass gulp-concat gulp-uglify gulp-rename--save-dev

gulp功能模块的文件会放在项目所在的目录的./node_modules 下

6、我们目前先使用一些简单的功能:
    - 检查Javascript
    - 编译Sass文件
    - 合并Javascript
    - 压缩合并并重命名Javascript

新建gulpfile.js 配置文件放在项目根目录下
 演示项目目录结构

  testProject    (项目名称)
  |–.git       通过git进行版本控制,项目自动生成这个文件
  |–node_modules   组件包目录
  |–dist       **发布环境**(编译自动生成的)
    |–css     样式文件(style.css style.min.css)
    |–images   图片文件(压缩图片\合并后的图片)
    |–js     js文件(main.js main.min.js)
    |–index.html 静态页面文件(压缩html)
  |–src       **开发环境**
    |–sass        sass文件
    |–images        图片文件
    |–js         js文件
    |–index.html     静态文件
  |–gulpfile.js       gulp配置文件
  |–package.json       依赖模块json文件,在项目目录下npm install会安装项目所有的依赖模块,简化项目的安装程序


现在,项目文件夹都建好,组件也安装完毕了,我们需要编写gulpfile.js文件以指定gulp需要为我们完成什么任务。
    gulpfile.js内容如下:

  // 引入gulp
  var gulp = require('gulp');

  // 引入组件
  var jshint = require('gulp-jshint');//检查js
  var sass  = require('gulp-sass');  //编译Sass
  var concat = require('gulp-concat');//合并
  var uglify = require('gulp-uglify');//uglify 组件(用于压缩 JS)
  var rename = require('gulp-rename');//重命名

  // 检查js脚本的任务
  gulp.task('lint', function() {
    gulp.src('./js/*.js') //可配置你需要检查脚本的具体名字。
      .pipe(jshint())
      .pipe(jshint.reporter('default'));
  });

  // 编译Sass
  gulp.task('sass', function() {
    gulp.src('./scss/*.scss')
      .pipe(sass())
      .pipe(gulp.dest('./css'));//dest()写入文件
  });

  // 合并,压缩js文件
  // 找到 js/ 目录下的所有 js 文件,压缩,重命名,最后将处理完成的js存放在 dist/js/ 目录下
  gulp.task('scripts', function() {
    gulp.src('./js/*.js')
      .pipe(concat('all.js'))
      .pipe(gulp.dest('./dist'))
      .pipe(rename('all.min.js'))
      .pipe(uglify())
      .pipe(gulp.dest('./dist'));

      console.log('gulp task is done');//自定义提醒信息
  });

  .... // 其他任务类似

  // 定义默认任务,执行gulp会自动执行的任务
  gulp.task('default', function(){
    gulp.run('lint', 'sass', 'scripts');

    // 监听js文件变化,当文件发生变化后会自动执行任务
    gulp.watch('./js/*.js', function(){
      gulp.run('lint','scripts');
    });
  });

7、现在,回到命令行窗口,可以直接运行gulp任务了。
    gulp

    这将执行定义的default任务,就和以下的命令式同一个意思

    gulp default

    当然,我们可以运行在gulpfile.js中定义的任意任务,比如,现在单独运行sass任务:

    gulp sass

8、编译会显示Finished,如果你的JS有什么不好的地方它会提醒,避免一些不必要的错误,十分贴心

    常见提醒:

    1.禁止在同一行声明多个变量。
    2.请使用 ===/!==来比较true/false或者数值
    3.使用对象字面量替代new Array这种形式
    4.不要使用全局函数。
    5.Switch语句必须带有default分支
    6.函数不应该有时候有返回值,有时候没有返回值。
    7.For循环必须使用大括号
    8.If语句必须使用大括号
    9.for-in循环中的变量 应该使用var关键字明确限定作用域,从而避免作用域污染。

9、gulp的插件数量很多,后面还可以根据自己的需要进行添加任务

    常用的gulp插件参考

    gulp-imagemin:         压缩图片
    gulp-ruby-sass:     支持sass,安装此版本需要安装ruby
    gulp-minify-css:     压缩css
    gulp-jshint:          检查js
    gulp-uglify:          压缩js
    gulp-concat:        合并文件
    gulp-rename:          重命名文件
    gulp-htmlmin:         压缩html
    gulp-clean:          清空文件夹
    gulp-livereload:     服务器控制客户端同步刷新(需配合chrome插件LiveReload及tiny-lr)

Use Git as a project management tool
安装git, 下载安装包会安装好 Git Shell 和可视化环境

    http://git-scm.com/download/win

配置用户名:

    git config --global user.name "Your Name"
    git config --global user.email "email@example.com"

关联一个到团队的库

    git remote add origin git@github.com:markyun/My-blog.git

添加文件到仓库,添加全部文件用 . 表示

    git add .

把文件提交到仓库

    git commit -m " first add project file"

提交文件到团队仓库

    git push -u origin master //将本地的项目提交到远程仓库中。

以上就完成了前端团队最基本的开发环境搭建和代码提交工作流程。

补充:ZSmart UED Team 的前端开发软件环境 (Windows, Linux, Mac OS X)
    安装Node.Js、NPM、Ruby、Java 基础环境
    Sublime Text3 + 插件           用于编写前端代码
    Google chrome 、Mozilla Firefox + Firebug
    Internet Explorer             进行兼容测试和预览页面UI、动画效果和交互功能
    Node.js+Gulp                 进行前端自动化构建、JS语法验证、CSS压缩,图片压缩等;
    Koala                         实时编译Less、Sass、Compass、CoffeeScript;
    Github                         存储自己的代码库 、git或SVN用于版本控制和团队Code Review
    Tomcat、DedeAMPZ、MAMP      进行简单运行环境演示
    Photoshop CC 切图 + Sprites 合并小图标
    XMind                         画出清晰的工作或业务逻辑思维图

(未完待续...)


# nodejs环境搭建  # nodejs开发环境搭建  # JavaScript 实现自己的安卓手机自动化工具脚本(推荐)  # JavaScript 常见安全漏洞和自动化检测技术  # 使用auto.js实现自动化每日打卡功能  # PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例  # Angular.js项目中使用gulp实现自动化构建以及压缩打包详解  # Angular.Js的自动化测试详解  # 从零搭建docker+jenkins+node.js自动化部署环境的方法  # Angular.js自动化测试之protractor详解  # python接口自动化(十七)--Json 数据处理---一次爬坑记(详解)  # JavaScript揭秘:实现自动化连连看游戏  # 放在  # 自己的  # 配置文件  # 重命名  # 目录下  # 自动生成  # 返回值  # 是一个  # 有什么  # 几个  # 运行环境  # 还可以  # 多个  # 你会  # 不需要  # 推荐使用  # 它是  # 所需  # 我们可以  # 请使用 


相关文章: 建站之星免费模板:自助建站系统与智能响应式一键生成  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  开源网站制作软件,开源网站什么意思?  代购小票制作网站有哪些,购物小票的简要说明?  小型网站制作HTML,*游戏网站怎么搭建?  定制建站如何定义?其核心优势是什么?  成都网站制作报价公司,成都工业用气开户费用?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  视频网站制作教程,怎么样制作优酷网的小视频?  c# 在高并发场景下,委托和接口调用的性能对比  建站之星如何实现网站加密操作?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  岳西云建站教程与模板下载_一站式快速建站系统操作指南  建站主机与服务器功能差异如何区分?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  无锡营销型网站制作公司,无锡网选车牌流程?  建站之星安装需要哪些步骤及注意事项?  建站主机是什么?如何选择适合的建站主机?  深圳网站制作平台,深圳市做网站好的公司有哪些?  建站之星价格显示格式升级,你的预算足够吗?  建站主机选购指南:核心配置优化与品牌推荐方案  建站主机系统SEO优化与智能配置核心关键词操作指南  建站之星如何快速解决建站难题?  设计网站制作公司有哪些,制作网页教程?  北京网站制作网页,网站升级改版需要多久?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  建站之星后台管理系统如何操作?  韩国服务器如何优化跨境访问实现高效连接?  如何用wdcp快速搭建高效网站?  企业微网站怎么做,公司网站和公众号有什么区别?  Swift中swift中的switch 语句  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  网站按钮制作软件,如何实现网页中按钮的自动点击?  广州营销型建站服务商推荐:技术优势与SEO优化解析  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何自定义建站之星网站的导航菜单样式?  网站制作软件免费下载安装,有哪些免费下载的软件网站?  测试制作网站有哪些,测试性取向的权威测试或者网站?  Swift中switch语句区间和元组模式匹配  网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?  如何在Golang中使用replace替换模块_指定本地或远程路径  如何通过网站建站时间优化SEO与用户体验?  西安专业网站制作公司有哪些,陕西省建行官方网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。