开发属于自己的yeoman脚手架(generator-reactpackage)
自从前后端开始分离之后,前端项目工程化也显得越来越重要了,之前写过一篇搭建基于Angular+Requirejs+Grunt的前端项目教程,有兴趣的可以点这里去看
但是有些项目可以使用这种方式,但有些却不太适合,或者我们就是想要去尝试新的框架。比如最近我就尝试着使用了webpack+react+es6的方式开发项目,感觉很不错,然后很多项目都用了这种方式。所以为了不需要每次开发的时候都从头开始新建文件,就想着能不能弄个工具,使用命令能够快速的生成这样一套跑的通的项目模版,正好,有个工具叫yeoman。
本篇文章看点:
教你使用
yeoman快速开发自己的脚手架。介绍作者编写的
generator-reactpackage脚手架模版,此项目的开发基于webpack+react+es6,项目功能包含:启动本地服务,默认监听端口8888
css文件能自动补全css3属性的前缀
包含路由功能(react-router)
使用命令
npm run dev启动服务,修改保存文件的时候浏览器会自动刷新(如果不想要实时刷新的功能,将webpack.config.js文件的devServer配置改为inline: false)使用
npm run build打包文件,js和css分开打包,并且默认会压缩文件
开发脚手架
环境准备
安装或者更新一下你的node和npm
npm install -g n //首先安装n模块
n stable //升级node.js到最新稳定版
n 5.0.0 //或者指定版本升级
node -v //检查更新是否成功
然后安装yeoman
npm install -g yo
创建目录
新建一个名为generator-xxx(yeoman脚手架命名规范)的文件夹,我这里叫generator-reactpackage。然后在目录下执行npm init创建package.json文件。修改为:
{
"name": "generator-reactpackage",
"version": "0.0.4",
"description": "基于ract+webpack的项目目录快速生成器",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"repository": {
"type": "git",
"url": "https://github.com/luckykun/generator-reactpackage.git"
},
"keywords": [
"yeoman-generator"
],
"author": "luckykun",
"license": "MIT",
"bugs": {
"url": "https://github.com/luckykun/generator-reactpackage/issues"
},
"homepage": "https://github.com/luckykun/generator-reactpackage",
"dependencies": {
"chai": "^3.3.0",
"chalk": "^1.1.1",
"fs-extra": "^0.24.0",
"mocha": "^2.3.3",
"yeoman-generator": "^0.24.1",
"yosay": "^1.0.5"
}
}
注意:package.json的信息一定要尽可能完整,不然可能上传不到generator-lists
然后在此目录下新建generators->app->index.js,generators-app-templates,如下图所示:

generator-reactpackage是整个npm包的项目文件夹。templates目录里面就是我们最后要用到的项目模版文件,里面的内容是一个完整的前端项目,可以自定义。index.js是开发脚手架的主要逻辑文件。
开始开发
然后编辑index.js文件:
var path = require('path');
var chalk = require('chalk'); //不同颜色的info
var util = require('util');
var yeoman = require('yeoman-generator');
var yosay = require('yosay'); //yeoman弹出框
var path = require('path');
var Reactpackage = yeoman.Base.extend({
info: function() {
this.log(chalk.green(
'I am going to build your app!'
));
},
generateBasic: function() { //按照自己的templates目录自定义
this.directory('src', 'src'); //拷贝目录
this.directory('data', 'data');
this.copy('package.json', 'package.json'); //拷贝文件
this.copy('index.html', 'index.html');
this.copy('README.md', 'README.md');
this.copy('webpack.config.js', 'webpack.config.js');
},
generateClient: function() {
this.sourceRoot(path.join(__dirname, 'templates'));
this.destinationPath('./');
},
install: function() { //安装依赖
this.installDependencies({
skipInstall: this.options['skip-install']
});
},
end: function() {
this.log(yosay(
'Your app has been created successfully!'
));
}
});
module.exports = Reactpackage;
上面这个文件就是主要逻辑部分了。至于具体的语法,可以参考这篇文章。快速搭建基于yeoman快速编写脚手架工具
上传
开发完成之后,我们就可以将generator-reactpackage这个项目上传到npm官网。步骤如下:
npm adduser //如果没有账号,用此命令注册
npm login //如果有账号,用此命令登陆
npm publish --access=public //上传到npm官网
上传成功后会提示:
+ generator-reactpackage@0.0.4
然后你可以访问http://yeoman.io/generators/这里去搜索一下自己的包,有没有上传成功,比如搜索reactpackage就会出现我上传的脚手架。如下图:

注意:
上传到npm官网之前需要先将脚手架项目上传到github
脚手架项目的package.json文件一定要尽可能详细,比如git主页,readme文件链接等等
如果你能搜到自己上传的脚手架了,OK,开发基于yeoman的脚手架工具就到这里结束了。有兴趣的同学可以去看看我编写的generator-reactpackage源码,喜欢的同学顺便来个star~~哈哈,感谢~
使用脚手架(generator-reactpackage)
首先确保自己安装了nodejs,然后全局安装yeoman
npm install -g yo
然后直接安装脚手架
npm install -g generator-reactpackage
在合适的地方新建一个文件夹,在文件夹下运行:
yo reactpackage
然后就会在此目录下生成以下目录结构:
├── data
│ └── test.json
├── src
│ ├── components
│ │ └── App.js
│ ├── images
│ │ └── yeoman.png
│ ├── styles
│ │ └── app.scss
│ ├── vendor
│ │ └── jquery.js
│ ├── views
│ │ └── home.html
├── node_modules
├── index.html
├── package.json
└── webpack.config.js
细心的同学可能已经发现,其实这里生成的内容就是我们脚手架中定义的templates目录下的内容。
然后使用以下命令:
npm run dev //项目开发过程使用,启动服务,实时刷新
npm run build //开发完成之后打包文件(js、css分开打包)
注意:
本项目默认监听端口是8888,所以在浏览器输入 http://localhost:8888 就能看到效果了
如果执行上述命令提示错误:
Error: getaddrinfo ENOTFOUND localhost,在host文件里面添加127.0.0.1 localhost即可监听端口和实时刷新的功能都能在
webpack.config.js文件中修改配置如果项目运行正常,会看到如下效果:

结语
可以看到,定义一个自己常用的脚手架骑士挺简单的,还有更多的功能有待探索。generator-reactpackage是一个基于webpack+react+es6开发的项目模版,有需要用到这个模版的同学就赶快安装用起来吧。
另外,它的源码已经上传到github上,喜欢generator-reactpackage的同学顺便给个star,多谢~~~
开发属于自己的yeoman脚手架(generator-reactpackage)的更多相关文章
- 前端工程化系列[06]-Yeoman脚手架核心机制
在前端工程化系列[05] Yeoman脚手架使用入门这边文章中,对Yeoman的使用做了简单的入门介绍,这篇文章我们将接着探讨Yeoman这个脚手架工具内部的核心机制,主要包括以下内容 ❏ Yeoma ...
- 前端工程化系列[05] Yeoman脚手架使用入门
Yeoman是一款流行的前端的脚手架工具. 脚手架工具可以用来快速的自动生成项目的必要文件和基础文件结构.Yeoman使用的内建命令为yo,同时它自己也是一个包管理工具和自动化任务工具,它基于特定的模 ...
- [springboot 开发单体web shop] 2. Mybatis Generator 生成common mapper
Mybatis Generator tool 在我们开启一个新项目的研发后,通常要编写很多的entity/pojo/dto/mapper/dao..., 大多研发兄弟们都会抱怨,为什么我要重复写CRU ...
- 利用yeoman快速搭建React+webpack+es6脚手架
自从前后端开始分离之后,前端项目工程化也显得越来越重要了,之前写过一篇搭建基于Angular+Requirejs+Grunt的前端项目教程,有兴趣的可以点这里去看 但是有些项目可以使用这种方式,但有些 ...
- 使用Yeoman快速启动AngularJS项目开发
本博客停止更新,请访问新个人博客:owenchen.net 前言 博客迁移到了BAE上,http://owenchen.net/,以后的文章会首发在自己的博客上,随后在博客园发布. 很久没有写文章了, ...
- 使用Yeoman generator来规范工程的初始化
前言 随着开发团队不断发展壮大,在人员增加的同时也带来了协作成本的增加:业务项目越来越多,类型也各不相同.常见的类型有基础组件.业务组件.基于React的业务项目.基于Vue的业务项目等等.如果想要对 ...
- Yeoman generator
使用Yeoman generator来规范工程的初始化 前言 随着开发团队不断发展壮大,在人员增加的同时也带来了协作成本的增加:业务项目越来越多,类型也各不相同.常见的类型有基础组件.业务组件.基于R ...
- 基于Yeoman实现自定义脚手架
什么是脚手架? Yeoman是什么? 实现自定义脚手架 基于Yeoman实现Vue-cli 一.什么是脚手架? 手脚架从功能上来讲就是创建项目初始文件,这其中包括生成功能模块配置.自动安装依赖.自动生 ...
- 如何学习web开发环境搭建和脚手架
Web前端的学习路线 第一阶段: HTML+CSS: HTML进阶.CSS进阶.div+css布局.HTML+css整站开发. JavaScript基础: Js基础教程.js内置对象常用方法.常见DO ...
随机推荐
- Openfire集群源码分析
如果用户量增加后为了解决吞吐量问题,需要引入集群,在openfire中提供了集群的支持,另外也实现了两个集群插件:hazelcast和clustering.为了了解情况集群的工作原理,我就沿着open ...
- Lesson 17 Always young
Text My aunt Jennifer is an actress. She must be at least thirty-five years old. In spit of this, sh ...
- 使用CSS3的box-shadow实现双透明遮罩层对话框
box-shadow介绍 在我之前的一篇文章<从天猫和支付宝身上学习opcity与rgba>中,介绍了实现双透明遮罩层效果的两种方法,分别是opacity和rgba.他们需要分别依赖于不同 ...
- .net垃圾回收机制编程调试试验
1. 什么是CLR GC? 它是一个基于引用跟踪和代的垃圾回收器. 从本质上,它为系统中所有活跃对象都实现了一种引用跟踪模式,如果一个对象没有任何引用指向它,那么这个对象就被认为是垃圾对象,并且可以被 ...
- 包含LOB_Data列的表删除大量数据后表及数据库文件的收缩
最近有一张表(内含varchar(max)字段),占用空间达到240G,删除历史数据后几十万条后,空间并未得到释放. 然后用DBCC CLEANTABLE(0,tb_name,100)来释放删除记录后 ...
- C#非常重要基础之多态
前几天看了一位同志的博客,写的是关于他自己去支付宝面试的经历.过程大体是这样的:问答的时候,前面部分,作者都应答如流,说起自己经验如何之丰富,最后面试官问了作者一个问题:请简述多态的概念和作用.结果这 ...
- VirtualBox 桥接上网方式的配置
最近在搞Redis所以装了个virtualbox的ubuntu的虚拟机, redis不是在ubuntu上. 因为需要使用本机客户端访问redis服务,所以需要配置虚拟机和本地机器的双向访问,所以就用到 ...
- git did not exit cleanly
exit code 1 1.鼠标右键 -> TortoiseGit -> Settings -> Network 2.SSH client was pointing to C:\Pr ...
- 前端学PHP之PDO预处理语句
× 目录 [1]定义 [2]准备语句 [3]绑定参数[4]执行查询[5]获取数据[6]大数据对象 前面的话 本来要把预处理语句和前面的基础操作写成一篇的.但是,由于博客园的限制,可能是因为长度超出,保 ...
- 从零开始编写自己的C#框架——框架学习补充说明
非常感谢轩辕公子提出了对本框架的看法与意见,所以这里也将回复贴出来,让大家都了解一下 本系列的快速开发指的是,框架构建完毕后,在这个基础上开发新功能非常快捷方便,基本不用写太多代码就可以在短时间内完成 ...