关于Grunt可视化的尝试

使用Grunt遇到的问题?

  • 必须要安装NodeJS
  • 必须安装grunt-cli
  • 需要编写复杂的Gruntfile.js规则
  • 每个项目中必须存在nodejs的grunt模块
  • 不方便管理每一个包含grunt的项目
  • 无法快速开始一个项目

解决思路

  • 直接把NodeJSgrunt-cli包含进去?
  • 弄个有UI的界面来管理?
  • 用程序简化gruntfile的规则?
  • 将所有项目中需要的grunt模块包含到一起?
  • 默认内置一些常用功能模块?

解决方案 -- nodewebkit

  • 集成了nodejs,省去NodeJS安装
  • 集成webkit内核,方便编写界面
  • 适合前端人员开发
  • 一次开发,兼容三大平台window/mac/linux

遇到问题

一.如何让NodeJS运行Grunt?

  1. 利用NodeJS的spawn运行cmd命令

    //切换运行环境到项目中
    process.chdir("项目地址");
    //执行grunt
    require("child_process").spawn("grunt");

    这种方案最简单,但需要依赖NodeJSgrunt-cli

  2. 将grunt-cli的模块直接引进代码中,利用nodejs调用

    var gruntpath = "grunt.js的路径";
    var grunt = require(gruntpath);
    grunt.cli();

    直接运行,提示找不到gruntfile.js,修改grunt文件夹中的task.js,大概在430行左右

    var old_path = process.cwd();//获取当前工作目录
    process.chdir('项目文件目录');//修改到项目目录
    var gruntfile = allInit ? null : grunt.option('gruntfile') ||
    grunt.file.findup('Gruntfile.{js,coffee}', {nocase: true});//查找gruntfile文件
    process.chdir(old_path);//修改回程序目录
    此处省略n行代码~~~
    (grunt.option('npm') || []).forEach(task.loadNpmTasks);//加载npm的模块
    process.chdir('项目文件目录');//切换到项目目录

    先切换到项目文件目录查找gruntfile.js文件,然后切换回程序目录查找node模块,运行完grunt后,程序自动退出了,囧,需要修改grunt下的exit.js

    process.exit(0);//这句需要注释掉

二.如何在子进程中运行Grunt?

  1. 利用NodeJS的child_process.fork

    var child = require("child_process").fork("child.js");
    child.onmessage = function(data){
    console.log(data);
    }
    child.on("exit",function(exitCode){
    console.log(exitCode);
    });

    --运行后提示:unzip the package xx/child.js,上网各种谷歌之后得出作者结论:

    child_process.fork is broken

    --囧,就是这个方法是不能用了?继续谷歌之后得知

    child_process.fork是无法运行js文件,它是直接运行执行命令nw 文件夹
    ,所以修改一下,在child文件夹中也放一个package.json文件,执行后,果然成功了。

    --然后又留下一个大问题,无法使用fork的通信接口,囧,最后只好用tcp来实现进程通信。

    --当我想打包成app测试的时候,发现,压根就不会运行子进程child

    因为child_process.fork是运行nw命令,所以,打包后是没有nw命令

  2. 利用NodeJS的webworker来执行

    npm install node-webworker

    之后引用worker.js

    var Worker  = require("worker.js");
    var workker = new Worker("child.js");
    worker.onmessage = function(data){
    console.log(data);
    }
    worker.postmessage({msg:'hello'});

    运行后,发现child.js中的任何信息都无法传递回给父进程,最后发现在worker.impl.buffer中保存了相关信息。

    var timeId = setInterval(function(){
    var msg = worker.impl.buffer;
    if(!msg)return false;
    console.log(msg);
    worker.imple.buffer = "";
    },1000);

    虽然很挫,但还是实现了功能了,打包测试,发现一切OK。发送到其它电脑测试,提示:

    spawn node not found,就是需要执行的命令找不到

    奇怪,我没调用spawn,哪来找不到?打开worker.js的源码查看,囧,发现:

    child_process.spawn("node xxx.js");

    囧,原来它是执行了node的命令来实现子进程,坑爹了。

  3. 利用HTML5的webworker

    var worker = new Worker("child.js");
    worker.onmessage = function(data){};
    worker.postmessage("hello");

    测试后,发现成功运行,消息也正常接收,可...webworker不支持运行nodejs代码,就是grunt无法跑起来。


三.目前可用方案

  1. 采用非子进程方式

    • 无法同时跑多个grunt任务
    • grunt没有提供结束的方法
    • 需要手动清除grunt的watch任务以及很多变量值,比较麻烦
    • 出错很可能会直接结束程序
  2. 独立将child内容打包成可执行文件,采用child_process.spawn执行

    • 需要打开两个可执行文件,两个加起来至少也有80M
    • 开发时,需要用fork,打包时候用spawn
  3. 安装NodeJS,采用webworker方式

    • 电脑必须安装了NodeJs
    • 目前较好的方案
    • 未来nodewebkit支持子进程方式,可以比较方便修改过来

PS:暂时还没发现其它可以跑子进程方式,求其他大神解救

 
 
 
标签: JavaScriptgrunt

关于Grunt可视化的尝试的更多相关文章

  1. 【Grunt】关于Grunt可视化的尝试

    使用Grunt遇到的问题? 必须要安装NodeJS 必须安装grunt-cli 需要编写复杂的Gruntfile.js规则 每个项目中必须存在nodejs的grunt模块 不方便管理每一个包含grun ...

  2. Kibana查询说明

    elasticsearch构建在Lucene之上,过滤器语法和Lucene相同 Kibana接口概述 Kibana接口分为四个主要部分: 发现 可视化 仪表板 设置 我们将按照列出的顺序浏览每个部分的 ...

  3. Gruntjs提高生产力(三)

    以下例子来自真实项目,有所删减 grunt-test project 目录结构如下 一我的目的: 1.在src-dev目录中开发最终产出于src目录 2.src-dev中的index目录相当于一个wi ...

  4. 解密国内BAT等大厂前端技术体系-阿里篇(长文建议收藏)

    进入2019年,大前端技术生态似乎进入到了一个相对稳定的环境,React在2013年发布至今已经6年时间了,Vue 1.0在2015年发布,至今也有4年时间了. 整个业界在前端框架不断迭代中,也寻找到 ...

  5. 解密国内BAT等大厂前端技术体系-百度篇(长文建议收藏)

    1 引言 整个业界在前端框架不断迭代中,也寻找到了许多突破方向,例如跨平台中的RN.Flutter,服务端GraphQL.Serverless,前端和客户端的融合越来越紧密,前端在Node和Elect ...

  6. 【大厂】389- 解密国内BAT等大厂前端技术体系-阿里篇(长文建议收藏)

    进入2019年,大前端技术生态似乎进入到了一个相对稳定的环境,React在2013年发布至今已经6年时间了,Vue 1.0在2015年发布,至今也有4年时间了. 整个业界在前端框架不断迭代中,也寻找到 ...

  7. ELK学习笔记之Kibana查询和使用说明

    0x00 概述 elasticsearch构建在Lucene之上,过滤器语法和Lucene相同 Kibana接口概述 Kibana接口分为四个主要部分: 发现 可视化 仪表板 设置 我们将按照列出的顺 ...

  8. 解密国内BAT等大厂前端技术体系-美团点评之上篇(长文建议收藏)

    引言 进入2019年,大前端技术生态似乎进入到了一个相对稳定的环境,React在2013年发布至今已经6年时间了,Vue 1.0在2015年发布,至今也有4年时间了. 整个业界在前端框架不断迭代中,也 ...

  9. 翻译——3_Gaussian Process Regression

    使用不同的机器学习方法进行预测 续上篇2_Linear Regression and Support Vector Regression 高斯过程回归 %matplotlib inline impor ...

随机推荐

  1. mac github工具将命令当下来的代码拖入macgithub中就可以

    mac github工具将命令当下来的代码拖入macgithub中就可以,刚開始傻傻的就知道点击那个加入button,总是在当下来的文件夹下创建个文件夹.并且代码不能同步

  2. 速度 Github

    首先需要了解.git 是版本号的管理工具,为了能够把任意代码托管执照:github 其中一个是. 应用 github 什么不该说的帐户. 那么,申请后,在需求 github 并建立了独特的本地机器上的 ...

  3. 使用flex和bison实现的sql引擎解析

    因为老师要求,近期在做oceanbase存储过程的实现,在oceanbase 0.4曾经是不支持存储过程的.实现的主要步骤主要包含 1.语法解析 2.词法解析 3.详细运行语法树的步骤 如今先来说说语 ...

  4. HHVM Installation and Configuration(HHVM 安装及配置)

    Installation and Configuration¶ General Installation Considerations Installation on Linux systems Ub ...

  5. leetcode -day31 Subsets I II

    1.  Subsets Given a set of distinct integers, S, return all possible subsets. Note: Elements in a ...

  6. Android自动化测试框架新书:交流

    大家觉得编写一本描述MonkeyRunner原理分析的书籍如何?估计大概10万字左右.内容大概分布如下: Monkey实现原理: 去描述运行在目标安卓机器的monkey是如何运行并处理MonkeyRu ...

  7. 【c#操作office】--OleDbDataAdapter 与OleDbDataReader方式读取excel,并转换为datatable

    OleDbDataAdapter方式: /// <summary> /// 读取excel的表格放到DataTable中 ---OleDbDataAdapter /// </summ ...

  8. Hbuilder常用快捷键功能.html

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. 基于Asterisk的VoIP开发指南——(2)Asterisk AGI程序编写指南

    原文:基于Asterisk的VoIP开发指南--(2)Asterisk AGI程序编写指南 5. Asterisk AGI程序编写指南 5.1概述 很多时候,我们需要在拨号方案中做某些业务逻辑的判断或 ...

  10. leetcode第33题--Search for a Range

    Given a sorted array of integers, find the starting and ending position of a given target value. You ...