zoukankan      html  css  js  c++  java
  • 如何使用Grunt(好文)

    Grunt 是什么?

    Grunt 基于Node.js之上,是一个以任务处理为基础的命令行工具,可以减少优化开发版本为发布版本所需的人力和时间,从而加速开发流程。它的工作原理是把这 些工作整合为不同的任务,在你开发时自动执行。基本上,你可以让Grunt完成任何让你厌烦的任务:那些你需要重复进行的手工设置和运行发布的任务。

    工具/原料

    • NodeJs
    • Windows系统

    方法/步骤

    1. 要使用Grunt,第一件事是安装Node.js。(即使你没用过Node.js也不用担心——你只需安装它让Grunt能运行。)

      安装了Node.js之后,用命令行工具执行以下命令:

      $ npm install -g grunt-cli

      要确认Grunt是否正确安装,可以使用以下命令:

      $ grunt --version

    2. 下一步是在你的项目的根目录下创建package.json和gruntfile.js两个文件。

      创建package.json文件

      这个JSON文件让我们指定我们的开发环境所依赖的必须模块。有了它,项目的所有开发者都能保证安装上一致的必须模块,从而保证所有人拥有一样的开发环境。

      在项目根目录下的pacakge.json文件中写上:

      {

          "name" : "SampleGrunt",

          "version" : "0.1.0",

          "author" : "Brandon Random",

          "private" : true,

          "devDependencies" : {

              "grunt" :                   "~0.4.0"

          }

      }

      然后在命令行工具运行:

      $ npm install

      该命令告诉npm 需要安装的必须模块,npm会安装它们,自动保存在项目根目录下一个叫做 node_modules 的文件夹里。

      创建gruntfile.js文件

      gruntfile.js 文件本质上就是一个wrapper函数,接受grunt作为参数:

      module.exports = function(grunt){

          grunt.initConfig({

              pkg: grunt.file.readJSON('package.json')

          });

          grunt.registerTask('default', []);

      };

      现在你已经可以在项目根目录下运行grunt命令行工具了。

      $ grunt

      > Task "default" not found. Use --force to continue.

      这里我们只指定了Grunt作为必须模块,还没定义任何任务。接下来我们就要指定任务和必须模块。首先来看如何拓展package.json文件。

    3. 拓展package.json文件

      使用Node.js最好的一点,就是它可以根据package.json文件的内容,一次性查找和安装多个package。要安装我们项目的所有必须任务,只须在package.json文件中加上以下内容:

      {

          "name" : "SampleGrunt",

          "version" : "0.1.0",

          "author" : "Mike Cunsolo",

          "private" : true,

          "devDependencies" : {

              "grunt" :                       "~0.4.0",

              "grunt-contrib-cssmin":         "*",

              "grunt-contrib-sass":           "*",

              "grunt-contrib-uglify":         "*",

              "grunt-contrib-watch":          "*",

              "grunt-cssc":                   "*",

              "grunt-htmlhint":               "*",

              "matchdep":                     "*"

          }

      }

      那么如何实现安装?你肯定已经猜到了:

      $ npm install

    4. 使用Grunt载入任务

      package安装好后,还必须被Grunt载入才能为我们所用。使用 matchdep,我们用一行代码就可以自动载入所有任务。这是开发流程的一大优化,因为现在我们只须把必须任务列表写在package.json一个文件里,便于管理。

      在gruntfile.js里,grunt.initConfig之上,写上以下代码:

      require("matchdep").filterDev("grunt-*").forEach(grunt.loadNpmTasks);

      要是没有matchdep,我们就必须为每一个必须任务写一次grunt.loadNpmTasks(“grunt-task-name”); ,随着我们使用的任务的增加,这些载入任务的代码很快就会变得相当繁冗。在Grunt载入这些任务前,我们还可以指定设置选项。

    5. 现在我们需要创建我们的HTML文件(index.html):

      <!DOCTYPE html>

      <html lang="en">

          <head>

              <meta charset="utf-8">

              <meta name="viewport"   content="width=device-width; initial-scale=1.0; maximum-scale=1.0;">

              <title>Enter your first name</title>

              <link rel="stylesheet"  href="build/css/master.css">

          </head>

          <body>

              <label for="firstname">Enter your first name</label>

              <input id="firstname" name="firstname" type="text">

              <p id="namevalidation" class="validation"></p>

              <script type="text/javascript" src="build/js/base.min.js"></script>

          </body>

      </html>

    6. 用HTMLHint验证HTML

      在grunt.initConfig里加入下列设置代码:

      htmlhint: {

          build: {

              options: {

                  'tag-pair': true,

                  'tagname-lowercase': true,

                  'attr-lowercase': true,

                  'attr-value-double-quotes': true,

                  'doctype-first': true,

                  'spec-char-escape': true,

                  'id-unique': true,

                  'head-script-disabled': true,

                  'style-disabled': true

              },

              src: ['index.html']

          }

      }

      一 般来说,一个plugin的设置方法如下:plugin的名称(去掉grunt-contrib-或grunt-前缀),选择使用此plugin的一个或 多个对象(在这里可以给不同文件设置此plugin 的不同选项),一个选项object,以及plugin要作用的对象。现在,如果我们用命令行工具运 行grunt htmlhint,该plugin就会检查我们在src里指定的HTML文件,验证其中有没有错误!但是每个小时都要手动运行几次这个任 务,很快就让人觉得很繁琐了。

    7. 自动化任务运行

      watch是一个特殊的任务,它可以在目标文件保存时自动触发一系列任务的运行。在grunt.initConfig里加入以下设置:

      watch: {

          html: {

              files: ['index.html'],

              tasks: ['htmlhint']

          }

      }

      然 后,在命令行工具中运行grunt watch命令。现在,你可以试试在index.html里加一行注释,保存文件。你会注意到,保存文件时会自动触发 HTML的验证!这是对开发流程的一大优化:在你写代码时,watch任务就会默默同时为你验证代码,如果验证失败任务就会报告失败(它还会告诉你问题在 哪)。

      注意grunt watch任务会一直运行,直到命令行工具关闭,或手动停止(control+c在Mac中)。

    8. 保持JavaScript极简

      让 我们来写一个验证用户输入的名字的JavaScript文件。简便起见,我们这里只检查其中是否含有非字母的字符。我们的JavaScript会使用 strict模式,这可以防止我们写可用但低质量的JavaScript。创建assets/js/base.js文件并在其中写上:

      function Validator()

      {

          "use strict";

      }

      Validator.prototype.checkName = function(name)

      {

          "use strict";

          return (/[^a-z]/i.test(name) === false);

      };

      window.addEventListener('load', function(){

          "use strict";

          document.getElementById('firstname').addEventListener('blur', function(){

              var _this = this;

              var validator = new Validator();

              var validation = document.getElementById('namevalidation');

              if (validator.checkName(_this.value) === true) {

                  validation.innerHTML = 'Looks good! :)';

                  validation.className = "validation yep";

                  _this.className = "yep";

              }

              else {

                  validation.innerHTML = 'Looks bad! :(';

                  validation.className = "validation nope";

                  _this.className = "nope";

              }

          });

      });

      让我们用UglifyJS来极简化这个源代码,在grunt.initConfig中加上以下设置:

      uglify: {

          build: {

              files: {

                  'build/js/base.min.js': ['assets/js/base.js']

              }

          }

      }

      UglifyJS会替换所有的变量和函数名,剔除所有空白和注释,从而生成占据最小空间的JavaScript文件,对发布非常有用。同样地,我们需要设置一个watch任务来使用它,在watch的设置里加入以下代码:

      watch: {   

          js: {

              files: ['assets/js/base.js'],

              tasks: ['uglify']

          }

      }

    9. 现在我们有了一个静态HTML页面,一个存放Sass和JavaScript源文件的assets文件夹,一个存放优化后的CSS和JavaScript的build文件夹,以及package.json文件和gruntfile.js文件。

      至此你已经有了一个不错的基础来进一步探索Grunt。像之前提到的,一个非常活跃的开发者社区在为Grunt开发前端plugin。我建议你现在就到plugin library 去看看那300个以上的plugin。

      END

    注意事项

    • Grunt.js 是一个JavaScript 任务运行工具,它能替你完成重复性的任务,如极简化、 编译、单元测试和linting。
  • 相关阅读:
    关于Android中图片大小、内存占用与drawable文件夹关系的研究与分析
    EventBus完全解析--组件/线程间通信利器
    【凯子哥带你学Framework】Activity启动过程全解析
    【凯子哥带你学Framework】Activity界面显示全解析
    APP的缓存文件到底应该存在哪?看完这篇文章你应该就自己清楚了
    全面理解Context
    Activity的四种launchMode
    Android动态加载框架汇总
    Android中Shape的使用
    Ninject简单的Demo
  • 原文地址:https://www.cnblogs.com/koleyang/p/5570591.html
Copyright © 2011-2022 走看看