使用yeoman构建angular应用的方法(2)

const path = require('path'); const mkdirp = require('mkdirp'); // ... default() { if (path.basename(this.destinationPath()) !== this.props.appName) { this.log( '发现你不是在 ' + this.props.appName + ' 目录下构建\n' + '我将主动创建此目录.(created folder with app name)' ); mkdirp(this.props.appName); this.destinationRoot(this.destinationPath(this.props.appName)); } }

三、writing方法

此方法即用来把实际项目按照指定规则给写出来,主要有两种写法: 直接复制指定模板以及传入参数渲染出目标文件。

方式一: 直接拷贝

this.fs.copy( this.templatePath('模板位置'), this.destinationPath('目标位置') );

方式二: 传入参数渲染模板

this.fs.copyTpl( this.templatePath('模板位置'), this.destinationPath('目标位置'), { 参数名: 值 } );

比如说,在index.js的同级目录下的templates目录下有一个文件叫text.txt, 使用方法一将模板位置和目标位置都写text.txt,老头就会直接复制这个text.txt作为输出;而如果使用方法二,模板位置和目标位置不变,并传入参数{ hello: '你好啊'},在text.txt中就使用ejs语法写上<%=hello%>,最终老头同样会输出一个test.txt文件,不一样的是里面的内容被渲染成了"你好啊"。

对此方法的总结就是根据需要使用copy或copyTpl进行输出,其中copyTpl中的渲染使用ejs语法进行,而模板文件就都放在index.js的同级templates目录里边。

四、install方法

此方法即用来自动执行依赖的安装,没什么特别的,就是在构建完成后自动帮你npm install和bower install,也可以禁用其中一种:

install() { this.installDependencies({bower: false}); }

效果就是下图这句话了:

使用yeoman构建angular应用的方法

发布generator到npm

发布之前可以先使用npm link映射到本地进行测试:

npm link yo ngtimo

确认无误后,发布流程就是一句代码的事(记得定好版本,且更新发布时记得更新版本号):

npm publish

以上这篇使用yeoman构建angular应用的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wydjyf.html