ionic generator是命令行的功能,ionic2自动帮我们创建应用程序,从而节省了大量的时间,并增加我们的速度来开发一个项目的关键部分。
ionic generator使我们可以自动创建以下几部份:
•component
•directive
•page
•provider
一、创建页面:ionic g page [pagename]
通过这个命令创建一个新的页面,ionic2项目中这个命令使用最多
我们只需要进入我们的命令行中,并运行下面的命令:
ionic g page login
# results:
√ create app/pages/login/login.html
√ create app/pages/login/login.scss
√ create app/pages/login/login.ts
login.ts:
import {component} from '@angular/core';
import {navcontroller} from 'ionic-angular';
@component({
templateurl: 'build/pages/login/login.html',
})
export class loginpage {
constructor(public nav: navcontroller) {}
}
login.html:
<ion-header>
<ion-navbar>
<ion-title>
login
</ion-title>
</ion-navbar>
</ion-header>
<ion-content padding class="login">
</ion-content>
二、创建组件:ionic g component [componentname]
组件是一段代码,可以在我们的应用程序的任何部分使用
通过这个命令创建一个组件:
ionic g component mycomponent
# results:
√ create app/components/my-component/my-component.html
√ create app/components/my-component/my-component.ts
my-component.ts:
import {component} from '@angular/core';
@component({
selector: 'my-component',
templateurl: 'build/components/my-component/my-component.html'
})
export class mycomponent {
text: string = "";
constructor() {
this.text = 'hello world';
}
}
三、创建指令:ionic g directive [directivename]
指令,我们的应用程序可以在任何元素上使用的修饰符属性.
ionic g directive mydirective
# results:
√ create app/components/my-directive/my-directive.ts
my-directive.ts:
import {directive} from '@angular/core';
@directive({
selector: '[my-directive]' // attribute selector
})
export class mydirective {
constructor() {
console.log('hello world');
}
}
四、创建服务提供者:ionic g provider [providername]
现在创建一个新的服务(提供者),提供者负责处理数据的rest api的连接,本地存储,sqlite的等等。
要创建它,我们去运行以下命令我们的终端:
ionic g provider userservice
# results:
√ create app/providers/user-service/user-service.ts
服务代码如下:
user-service.ts:
import {injectable} from '@angular/core';
import {http} from '@angular/http';
import 'rxjs/add/operator/map';
@injectable()
export class userservice {
data: any = null;
constructor(public http: http) { }
load() { if (this.data) {
}
return new promise(resolve => {
this.http.get('path/to/data.json')
.map(res => res.json())
.subscribe(data => {
this.data = data;
resolve(this.data);
});
});
}
}
五、创建管道pipe:ionic g pipe [pipename]
该管道的变化,我们可以对任何数据使用我们的模板,如以大写字母显示文本,显示货币值,日期格式等。
ionic g pipe mypipe
# results:
√ create app/pipes/mypipe.ts
我们的管道的代码如下
mypipe.ts:
import {injectable, pipe} from '@angular/core';
@pipe({
name: 'my-pipe'
})
@injectable()
export class mypipe {
transform(value: string, args: any[]) {
value = value + ''; // make sure it's a string
return value.tolowercase();
}
}
最后,我们生成的应用程序结构如下图:
我们的项目将存放在一个更加有序和更多的控制方式,这一切都可以手动实现,但用ionic generator来做,可以节省宝贵的时间来创造这些内容。
相关推荐:
有关ionic2懒加载配置介绍
ionic2系列之使用deeplinker实现指定页面url
ionic2自定义cordova插件开发_javascript技巧
以上就是ionic2中如何使用自动生成器的详细内容。