Ionic2学习笔记
Component
nav:
<ion-nav [root] = 'rootComponent'></ion-nav>
....
import {Nav} from 'ionic-angular';
....
export class AppComponent{
@ViewChild(Nav) private nav:Nav;
push(){
nav.push(PageOne,{id:1,name:'ztw'});
}
} @Component({template:`<p>{{show}}</p><button (click)='goBack()'> back</button>`})
export class PageOne{
show:string
constructor(
private:navParams:NavParams,
private:navCtrl:NavController
){}
ngOnInit(){
let name:string=navParams.get(name);
let id:number=+navParams.get(id);
this.show=`name : ${name} , id: ${id}`;
};
goBack(){
this.navCtrl.pop(); //this.navCtrl.popToRoot(); 回到root
}
}
可以通过@ViewChild(Nav)navCtrl,访问内部属性;
navCtrl.setRoot(component:Component) ; //其实等同于rootComponent=component ;
.pop(); //等同于new ViewController().dismiss();
.push(component, {param:value} ,...); //通过 new NavParams().get(param)获得
.insert(index,component,{param:value},...);
Menu:
<ion-menu [content]='content' silde='right' id='authenticated'>
<button menuClose> close</button>
<button menuOpen>open</button>
<button menuToggle>toggle</button>
</ion-menu>
<ion-menu silde='left' id='unauthenticated'> </ion-menu>
<nav-ion #content> <nav-ion>
属性:
import {MenuControll} from 'ionic-angular';
new MenuControll().open()
.close()
.toggle('left') ;//多个menu,且不在同一位置时,可使用位置来控制;
.enable(ture,'authenticated'); //多个menu时,以ID来控制。
ViewController:
属性:
willEnter; ngOnChanges
didEnter ; ngOnInit
willLeave; before unActive
didLeave; after unActive
willUnload; after ngOnDestroy;
// all return Observable ;使用:
this.viewCtrl.didEnter.subscribe(val=>{console.log('didEnter')});
事件:
onDidDismiss();OnWillDismiss();
方法:
dismiss();
.....
alerts:
let alertCtrl=new AlertController();
alertCtrl.create({
title:'alert msn',
message:' msn'
buttons:[
{text:' ok' ,
hanlder:data=>{console.log(data)},
}] ,
inputs:[
{type:'text',name:'name',placeholder:'account'},
]
})
类似于绑定了一个#form='ngForm' 或者 [fromGroup]='form';
而每个button的hanlder中返回的data,则为form.value;
Config:
import {IonicModule} from 'ionic-angular';
@NgModule({
imports:[
IonicModule.forRoot(MyApp,opt,DeepLinkers)
]
})
opt={ iocnMode:'ios' , modelEnter:'model-silde-in'};
DeepLinkers;
Ionic2中的页面导航不显示在URL上。
而在DeepLinkers中设置了的component,可以在url上导航,as a breadCrumb。
DeepLinkers={ links:[{component:PageComponent,name:'page' , segment : 'pageOne' , defualtHistory:'HomePage'}]} //url为http://localhost:8100/#/pageOne;
defualtHistory:PageComponent在没有设置返回时,会自动设置back button。导航至HomePage.
InfiniteScroll && Refresher:
...
template:`
<ion-content>
<ion-list><ion-item></ion-item></ion-list>
<ion-infinite-scroll (ionInfinite)='do($event)'>
<ion-infinite-scroll-content loadingSpinner='' loadingText=''>
//<ion-refresh-content refreshSpinner='' refreshText=''></..> </ion-infinite-scroll-content>
</ion-infinite-scroll>
</ion-content>
`
......
export class Page{
.......
do(inifinate){
if(end) return inifinate.enable(false);
Http.get(...);
inifinate.complate();
}
}
ion-infinite-scroll-content:控制载入等待时的样式;
没有data可供加载时,使用inifinate.enable(false),使其失效。
refresher使用方法大致相同,用于向上刷动。
RadioGroup:
<ion-list radio-group [(ngModel)]='getRadio'>
<ion-item>
<ion-label> one</ion-label>
<ion-radio value='one'> </ion-radio>
</ion-item>
</ion-list>
设置了radio-group后,getRadio可获得选中值,radio-group为单选。
Segment:
<form [formGroup]='form'>
<ion-segment [formControlName] ='"segment"'> // 也可以使用<ion-segment [(ngModel)]='getSegment'>将button的value连接到getSegment. <ion-segment-button value='one' >one </..>
<ion-segment-button value='two'>two </..>
</ion-segment>
使用formGroup;可以直接使用this.form.form.get('segment').valueChanges来进行监听。
我的例子:https://github.com/zhantewei2/Ionic2-example-notes/tree/master/pages/testSegment
这个例子是一个比较笨拙的方法。
<ion-segment [ngModel]='segment' (ngModelChange)='Changed($event)'>使用这样可以,对value改变事件进行监听。
ItemSliding:
<ion-item-sliding #slide (ionDrag)='drag($event)'>
<ion-item-option icon-left (ionSwipe)='Swiped()'>
<button item-button (click)='close(slide)'>
<item-icon name='archive'></item-con>
button
</button>
</ion-item-option> export class Test{
subject:any;
ngOnInit(){
this.subject=Subject.thrrotleTime(300).subscribe(val=>{console.log(val)})
}
drag(e){
this.subject.next(e.getSlidingPercent()); //获得item-sliding的滑动范围。
}
close(node){
node.close() //关闭item-sliding
}
}
方法.close();
事件:ionDrag();
<ion-item-option> :ionSwipe(); //滑动成功时触发。
ionReorder:不建议使用。
Ionic2学习笔记的更多相关文章
- Ionic2学习笔记(10):扫描二维码
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5575843.html 时间:6/11/2016 说明: 在本文发表的时候(2016-06-1 ...
- Ionic2学习笔记(9):访问本地设备
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5559927.html Ionic2提供了访问本地设备的方法,但是需要安装 ...
- Ionic2学习笔记(8):Local Storage& SQLite
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5557947.html Ionic2可以有两种方式来存储数据,Local S ...
- Ionic2学习笔记(7):Input
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5554610.html 我们先来看一个简单的输入用户名和密码点击登录的界面: ...
- Ionic2学习笔记(6):Navigation
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5551535.html Ionic2中创建一个页面很方便,在页面之间相互切换也很方 ...
- Ionic2学习笔记(5):Provider
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5547646.html Provider是一种为App提供数据源的方式, 举个 ...
- Ionic2学习笔记(0):HelloWorld
作者:Grey 原文地址:http://www.cnblogs.com/greyzeng/p/5529153.html 操作系统: Windows 10 环境配置: Node.js Java SE D ...
- Ionic2学习笔记(4):*号
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5544479.html 大家常常会在ionic2页面中见到*号 ...
- Ionic2学习笔记(3):Pipe
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5538630.html Pipe类似过滤器,比如,在一个字符串要展现在页面之前, 我们需要对这个字符串 ...
- Ionic2学习笔记(2):自定义Component
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5536298.html 上一篇提到,Ionic2提供了很多Co ...
随机推荐
- Java基础&笔试题
这些题目是近期我参加过的笔试题和一些我在网上选的部分题,在这里做笔记,认真去学习,更好的应对后面的招聘.有错误欢迎指出. 一.Java基础部分 1.指针在任何情况下都可进行>,<,> ...
- 前端:IE兼容性的相关方法
有一段时间做前端的时候,IE下的就兼容性是比较令人头痛的问题,我在这一过程中也是看了很多的资料,然后把一些自己觉得比较普遍的问题进行一下相关的总结. 1.在IE6下,格式为png的图片在IE6上的透明 ...
- js回顾1
1.正则:/^[0-9a-zZ-Z_]*&/ //匹配0到多个,+是1到多个,?0或多个,.任意值/^[0-9a-zZ-Z_]{6,}&/ //精确到至少6位\w查找单词字符检测:te ...
- android studio 中依赖库compile 的一些库的地址
1.添加Gson的依赖库 compile 'com.google.code.gson:gson:2.2.4' 2.使用Volley执行网络数据传输的依赖库 compile 'com.mcxiaoke. ...
- CSS3背景
1.背景的五种基本属性 background-color(背景颜色) background-image(背景图片) background-repeat(背景图片展示方式) background-a ...
- VMware下利用ubuntu13.04建立嵌入式开发环境之四
二.telnet.SSH服务器安装与配置 1.telnet 1.1 安装服务器:apt-get install xinetd telnetd 1.2 安装openbsd-inetd:apt-get i ...
- jquery实现css3动画
jquery animate改变元素样式时,只支持数字值的变化,比如width,height等,但是css3属性状态值很多都不是数字值,而是字符串和数字混合在一起,比如translate(), rot ...
- MySQL中DATETIME、DATE和TIMESTAMP类型的区别
一.TIMESTAMP 显示格式:YYYY-MM-DD HH:MM:SS 时间范围:[ '1970-01-01 00:00:00'到'2037-12-31 23:59:59'] TIMESTAMP D ...
- STL库中的正态分布函数
在设计抽奖一类程序中,有时会需要一种概率“有较大可能获得一个普通结果,有较小可能获得一个糟糕或极好的结果”,这就可以用正态分布函数来获得这样一个结果. STL中已经提供了一系列随机分布的函数,包括正态 ...
- 使用OpenCV&&C++进行模板匹配.
一:课程介绍 1.1:学习目标 学会用imread载入图像,和imshow输出图像. 用nameWindow创建窗口,用createTrackbar加入滚动条和其回调函数的写法. 熟悉OpenCV函数 ...