前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的数据,同样,react中的redux和mbox也是,但遇到angular5却不知道了。
一年前使用过angular1.x做过项目,那时全局状态可以使用$rootscope,也可以使用服务Service实现,下面就用Service方式在angular5中实现下吧
先定义状态管理对象,需要存什么数据,自己定义
export class UserInfo {
public userInfo: boolean;
constructor(){
this.userInfo = true; //设置全局的控制导航是否显示
}
}
然后定义Service,如下
import { Injectable} from '@angular/core';
import { Headers, Http } from '@angular/http';
import { UserInfo } from './user-info.model';
@Injectable() //注入服务
export class ListsService{
private userInfo;
constructor(private http: Http) {
this.userInfo = new UserInfo();
}
//设置路由显示的状态
setUserInfo(v) {
this.userInfo.userInfo = v;
}
//获取路由显示的状态
getUserInfo() {
return this.userInfo;
}
}
配置了service一定要在ngmodule中导入,这样才能在此module中有效
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { HttpModule } from '@angular/http';
import { AppComponent } from './app.component';
import { AppRouterModule } from './router.module';
import { ViewComponent } from './view.component';
import { ListComponent } from './list.component';
import { OtherComponent } from './other.component';
import { DetailComponent } from './detail.component';
import { ListsService } from './app.service';
@NgModule({
declarations: [
AppComponent,
DetailComponent,
ViewComponent,
ListComponent,
OtherComponent
],
imports: [
BrowserModule,
FormsModule ,
AppRouterModule,
HttpModule
],
providers: [ListsService],
bootstrap: [AppComponent]
})
export class AppModule { }
然后就可以在component中使用了
@Component({
selector: 'app-root',
template: `
<div >
<div class="lists" *ngIf='userInfo.userInfo'>
<a routerLink="/view" routerLinkActive ="active">特价展示</a>
<a routerLink="/list" routerLinkActive ="active">列表展示</a>
</div>
<router-outlet></router-outlet>
</div>
`,
styles:[`
.lists a{
padding:0 10px;
}
.active{
color: #f60;
}
`]
})
export class AppComponent {
private userInfo;
constructor(private listsService: ListsService) {
this.userInfo= this.listsService.getUserInfo();
}
}
在详情页中通过改变状态来改变页面
@Component({
selector: 'app-detail',
template: `
<div>
详情页{{id}}
<button (click)="goBack()">返回</button>
</div>
`,
})
export class DetailComponent {
private userInfo;
constructor(
private route: ActivatedRoute,
private location: Location,
private listsService: ListsService
) {
this.userInfo= this.listsService.setUserInfo(false);
}
goBack(): void {
this.location.back();
}
//组件销毁时执行
ngOnDestroy():void{
this.userInfo= this.listsService.setUserInfo(true);
}
}
好了,这样就ok了。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
Angular5,状态管理
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。