grunt学习二

1. 新建文件和文件目录

mkdir grunt-in-action
cd grunt-in-action
cd grunt-in-action
mkdir grunt-empty
cd grunt-empty

vim index.html
mkdir js
cd js
vim index.js
cd ..

2. npm和grunt初始化

npm init
npm install grunt --save-dev
npm install //如果想要node_module,就 加载

3. 安装task

npm install load-grunt-tasks --save-dev

npm install time-grunt --save-dev

npm install grunt-contrib-copy --save-dev

npm install grunt-contrib-clean --save-dev

4. 写入好配置

‘use strict‘;

module.exports = function (grunt) {
    //引入执行task的grunt插件或者叫做module
    require(‘load-grunt-tasks‘)(grunt);
    //引入执行事件显示grunt的模块
    require(‘time-grunt‘)(grunt);

    var config = {
        app: ‘app‘, //app 代表app目录
        dist: ‘dist‘ //dist 代表dest目录
    }

    grunt.initConfig({
        config: config,

        //copy任务
        copy: {
            /*
             //字符串形式的
             dist_html: {
             //src 表示源文件
             src: ‘<%= config.app %>/index.html‘,
             //dest 表示布标文件
             dest: ‘<%= config.dist %>/index.html‘
             },
             dist_js: {
             src: ‘<%= config.app %>/js/index.js‘,
             dest: ‘<%= config.dist %>/js/index.js‘
             }
             */
            /*
             //数组形式
             dist: {
             files: [
             {
             src: ‘<%= config.app %>/index.html‘,
             dest: ‘<%= config.dist %>/index.html‘
             },
             {
             src: ‘<%= config.app %>/js/index.js‘,
             dest: ‘<%= config.dist %>/js/index.js‘
             }
             ]
             }*/
            //对象简直对
            dist: {
                /*files: {
                    ‘<%= config.dist %>/index.html‘:‘<%= config.app %>/index.html‘,
                    ‘<%= config.dist %>/js/index.js‘: [‘<%= config.app %>/js/index.js‘]
                }*/
                files: [
                    {
                        expand: true,
                        cwd: ‘<%= config.app %>/‘, //表示源码目录
                        // src: ‘*.html‘,
                        src: ‘**/*.js‘,
                        dest: ‘<%= config.dist %>/‘, //表示目标路
                        ext: ‘.js‘, //后缀名匹配
                        // extDot: ‘first‘ //表示文件名第一个点之后内容与src匹配
                        extDot: ‘last‘,//表示文件名最后一个点之后的内容与src匹配
                        flatten: true, //表示平铺,意思在dist目录下就生成了,而不再生成目标子级目录
                        rename: function(dest,src){ //重命名
                            /*
                            * rename 要在ext extdot flatten开启才有效
                            * dest 表示目标目录
                            * src 表示文件名
                            * */
                            return dest + ‘js/‘ + src;
                        },
                    }
                ]
            }
        },
        //清楚任务,注意看英语单词就能理解其意思
        clean: {
            dist: {
                /*
                 src: ‘<%= config.dist %>‘,
                 */
                //这里面的*类似正则
                src: [‘<%= config.dist %>/**/*‘],
                // src: ‘<%= config.dist %>/‘
                //额外参数
                /*
                * filter: fn(param1);
                *param1 表示文件目录
                * */
                // filter: function (filepath) {
                //     return (!grunt.file.isDir(filepath));
                // }
                /*
                * nonull
                * dot
                * matchBase
                * expand
                * */
            }
        }
    });
};

5.运行grunt

grunt copy //运行copy task

grunt  clean //运行clean task

6.最终的目录结构

时间: 2024-11-06 11:39:46

grunt学习二的相关文章

[Python 学习] 二、在Linux平台上使用Python

这一节,主要介绍在Linux平台上如何使用Python 1. Python安装. 现在大部分的发行版本都是自带Python的,所以可以不用安装.如果要安装的话,可以使用对应的系统安装指令. Fedora系统:先以root登入,运行 yum install python Ubuntu系统:在root组的用户, 运行 sudo apt-get install python 2. 使用的Python的脚本 Linux是一个以文件为单位的系统,那么我们使用的Python是哪一个文件呢? 这个可以通过指令

OpenCV for Python 学习 (二 事件与回调函数)

今天主要看了OpenCV中的事件以及回调函数,这么说可能不准确,主要是下面这两个函数(OpenCV中还有很多这些函数,可以在 http://docs.opencv.org/trunk/modules/highgui/doc/user_interface.html 找到,就不一一列举了),然后自己做了一个简单的绘图程序 函数如下: cv2.setMouseCallback(windowName, onMouse[, param]) cv2.createTrackbar(trackbarName,

Makefile持续学习二

Makefile概述 一.Makefile里有什么? Makefile里主要包含5个东西:显式规则.隐晦规则.变量定义.文件指示和注释 1.显式规则:显式规则说明如恶化生成一个或多的目标文件,包含要生成的文件,文件的依赖文件,生成的命令 2.隐晦规则:由make自动推动功能完成 3.变量定义:变量一般都是字符串,类似C语言中的宏定义,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上 4.文件指示: 在一个Makefile中引用另一个Makefile 根据某些情指定Makefil

redis ruby客户端学习( 二)

接上一篇redis ruby客户端学习( 二) 对于redis的五种数据类型:字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets),上一篇介绍了字符串. 1,哈希(Map) hset.设置 key 指定的哈希集中指定字段的值.如果 key 指定的哈希集不存在,会创建一个新的哈希集并与 key 关联.如果字段在哈希集中存在,它将被重写. require "redis" r = Redis.new r.hset 'my_h

Duilib学习二 第一个程序 Hello World

Duilib学习二  第一个程序 Hello World #pragma once #include <UIlib.h> using namespace DuiLib; #ifdef _DEBUG # ifdef _UNICODE # pragma comment(lib, "DuiLib_ud.lib") # else # pragma comment(lib, "DuiLib_d.lib") # endif #else # ifdef _UNICOD

Jquery Easy UI初步学习(二)datagrid的使用

第一篇学的是做一个管理的外框,接着就是数据datagrid绑定了,这里我用asp.net mvc3来做的,主要就是熟悉属性.方法. 打开easyui的demo 就可以看到如下一段代码: 和上篇一样class="easyui-datagrid", data-options="...",这是一样的,其他我在网上查了查,并做了整理 DataGrid 属性 参数名 类型 描述 默认值 title string Datagrid面板的标题 null iconCls strin

Oracle学习(二):过滤和排序

1.知识点:可以对照下面的录屏进行阅读 SQL> --字符串大小写敏感 SQL> --查询名叫KING的员工信息 SQL> select * 2 from emp 3 where ename = 'KING'; SQL> --日期格式敏感 SQL> --查询入职日期为17-11月-81的员工 SQL> select * 2 from emp 3 where hiredate='17-11月-81'; --正确例子 SQL> ed 已写入 file afiedt.b

Jetty学习二:配置概览-怎么配置Jetty

Jetty POJO配置 Jetty的核心组件是Plain Old Java Objects(POJOs):配置Jetty的大部分工作就是在Jetty POJOs上的初始化.装配和设置域的处理,你能通过以下的方式来实现:  1)直接通过Java代码初始化和装配Jetty对象.这个在后面Embedding Jetty讲. 2)用Jetty XML配置(一个控制反转(IoC)框架)初始化和装配Jetty对象.etc/jetty.xml文件是基本的Jetty XML配置文件,但有一些其它的etc/je

nodejs学习二 深入了解console

上一篇我们用console.log编写了第一个程序,虽然如此简单.那么我就从它来说说Node.js中的对象. 对于学过Java .net 的人来说,对象这个词应该都很亲切,如果不觉得亲切,还是先学习一下面向对象. 我们编程中,一切皆对象.你可以把任何一个东西当做对象. 然而,Node.js中也存在对象,而console也是一种对象.既然是对象,他应该有公有的方法.正如你所看到的,log就是它的方法,貌似还是静态的. 那么console中有哪些方法呢,那我们就让他输出一下吧. 噢,原来consol