【Grunt】关于Grunt可视化的尝试
使用Grunt遇到的问题?
- 必须要安装
NodeJS - 必须安装
grunt-cli - 需要编写复杂的
Gruntfile.js规则 - 每个项目中必须存在nodejs的
grunt模块 - 不方便管理每一个包含grunt的项目
- 无法快速开始一个项目
解决思路
- 直接把
NodeJS跟grunt-cli包含进去? - 弄个有UI的界面来管理?
- 用程序简化gruntfile的规则?
- 将所有项目中需要的grunt模块包含到一起?
- 默认内置一些常用功能模块?
解决方案 -- nodewebkit
- 集成了
nodejs,省去NodeJS安装 - 集成
webkit内核,方便编写界面 - 适合前端人员开发
- 一次开发,兼容三大平台window/mac/linux
遇到问题
一.如何让NodeJS运行Grunt?
利用NodeJS的spawn运行cmd命令
//切换运行环境到项目中
process.chdir("项目地址");
//执行grunt
require("child_process").spawn("grunt");这种方案最简单,但需要依赖
NodeJS跟grunt-cli将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.jsprocess.exit(0);//这句需要注释掉
二.如何在子进程中运行Grunt?
利用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命令利用NodeJS的webworker来执行
npm install node-webworker之后引用
worker.jsvar 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的命令来实现子进程,坑爹了。利用HTML5的webworker
var worker = new Worker("child.js");
worker.onmessage = function(data){};
worker.postmessage("hello");测试后,发现成功运行,消息也正常接收,可...
webworker不支持运行nodejs代码,就是grunt无法跑起来。
三.目前可用方案
采用非子进程方式
- 无法同时跑多个grunt任务
- grunt没有提供结束的方法
- 需要手动清除grunt的watch任务以及很多变量值,比较麻烦
- 出错很可能会直接结束程序
独立将child内容打包成可执行文件,采用child_process.spawn执行
- 需要打开两个可执行文件,两个加起来至少也有80M
- 开发时,需要用fork,打包时候用spawn
安装NodeJS,采用webworker方式
- 电脑必须安装了NodeJs
- 目前较好的方案
- 未来nodewebkit支持子进程方式,可以比较方便修改过来
PS:暂时还没发现其它可以跑子进程方式,求其他大神解救
【Grunt】关于Grunt可视化的尝试的更多相关文章
- 关于Grunt可视化的尝试
关于Grunt可视化的尝试 使用Grunt遇到的问题? 必须要安装NodeJS 必须安装grunt-cli 需要编写复杂的Gruntfile.js规则 每个项目中必须存在nodejs的grunt模块 ...
- 杂项-Grunt:grunt build 打包和常见错误
ylbtech-杂项-Grunt:grunt build 打包和常见错误 1. 安装.打包返回顶部 1. npm WARN deprecated coffee-script@: CoffeeScrip ...
- 【grunt】grunt 基础学习
1. 干啥的呢? 项目打包管理,用处有 1)可用于压缩合并前端文件,包括css/js , 2)可用于管理发布文件与开发文件,3)可用于自动编译less 文件 2. 常用的东西有哪些呢? 常用的插件有 ...
- 高效开发之SASS篇 灵异留白事件——图片下方无故留白 你会用::before、::after吗 link 与 @import之对比 学习前端前必知的——HTTP协议详解 深入了解——CSS3新增属性 菜鸟进阶——grunt $(#form :input)与$(#form input)的区别
高效开发之SASS篇 作为通往前端大神之路的普通的一只学鸟,最近接触了一样稍微高逼格一点的神器,特与大家分享~ 他是谁? 作为前端开发人员,你肯定对css很熟悉,但是你知道css可以自定义吗?大家 ...
- Grunt-cli的执行过程以及Grunt加载原理
通过本篇你可以了解到: 1 grunt-cli的执行原理 2 nodeJS中模块的加载过程 Grunt-cli原理 grunt-cli其实也是Node模块,它可以帮助我们在控制台中直接运行grunt命 ...
- 【GruntMate】一个让你更方便使用Grunt的工具
GruntMate是什么? 一个基于Grunt的项目管理可视化工具(还不知道Grunt是什么?可以谷歌一下就知道了!) GruntMate有哪些功能? 方便的管理基于Grunt的项目 方便统一管理Gr ...
- Grunt教程——初涉Grunt
前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为庞大和复杂,代码维护.打包.发布等流程也 变得极为繁琐,同时浪费的时间和精力也越来越多,当然人为的错误 ...
- 使用Grunt启动和运行
开始使用Grunt 大多数开发人员都一致认为,JavaScript开发的速度和节奏在过去的几年里已经相当惊人.不管是Backbone.js和Ember.js的框架还是JS Bin社区,这种语言的发展变 ...
- 【转】自动化任务运行器 Grunt 迅速上手
原文转自:http://blog.jobbole.com/51586/ 这篇文章将带领你用Grunt来提速和优化网站开发的流程.首先我们会简短介绍Grunt的功能,然后我们直接上手,介绍如何用Grun ...
随机推荐
- [PHP]array_map与array_column之间的关系
---------------------------------------------------------------------------------------------------- ...
- WinFrom 只启动一个exe,并且获得焦点
只启动一个exe方法: using System; using System.Collections.Generic; using System.Runtime.InteropServices; us ...
- System.gc()与Object.finalize()的区别
finalize()是由JVM自动调用的,你可以用System.gc(),但JVM不一定会立刻执行,JVM感觉内存空间有限时,才会开始执行finalize(),至于新的对象创建个数和被收集个数不同是因 ...
- Android Studio-导入External Libraries
1.导入本地Libraries 1 拷贝 gson-2.3.1.jar(gson-2.3.1.jar为例)到 app/libs 目录下 2 在app/build.gradle的 dependencie ...
- 10 steps to becoming the developer everyone wants
You thought it was all about programming skills. But you were wrong! Great code is fine, yet command ...
- Clustering by fast search and find of density peaks
参考:http://www.52ml.net/16296.html 这个算法的优点就在于,它首先一步就能找到聚类中心,然后划分类别.而其他算法需要反复迭代才能找到中心聚类. 就是不知道代码该怎么写.. ...
- [ruby on rails] 跟我学之(4)路由映射
前面<[ruby on rails] 跟我学之Hello World>提到,路由对应的文件是 config/routes.rb 实际上我们只是添加了一句代码: resources :pos ...
- Redis使用介绍
Redis 是一个高性能的key-value数据库. redis的出现,很大程度补偿了memcached这类keyvalue存储的不足,在部 分场合可以对关系数据库起到很好的补充作用.它提供了Pyth ...
- 如何实现SSH断开后 进程仍然在后台运行
1.nohup命令功能:不挂断地运行命令,忽略HUP信号.语法:nohup command & 实例:nohup ping www.google.com & 转自: http://bl ...
- php 今天 昨天 明天 时间戳
2013年9月10日 16:26:25 echo strtotime('now'),'<br>'; echo strtotime('today'),'<br>'; echo s ...