Angular5中狀態(tài)管理的實(shí)現(xiàn)
前面學(xué)習(xí)了vue,react 都有狀態(tài)管理,如vue中的vuex是全局狀態(tài)管理,在任何組件里都可以引用狀態(tài)管理中的數(shù)據(jù),同樣,react中的redux和mbox也是,但遇到angular5卻不知道了。
一年前使用過angular1.x做過項(xiàng)目,那時(shí)全局狀態(tài)可以使用$rootscope,也可以使用服務(wù)Service實(shí)現(xiàn),下面就用Service方式在angular5中實(shí)現(xiàn)下吧
先定義狀態(tài)管理對(duì)象,需要存什么數(shù)據(jù),自己定義
export class UserInfo {
public userInfo: boolean;
constructor(){
this.userInfo = true; //設(shè)置全局的控制導(dǎo)航是否顯示
}
}
然后定義Service,如下
import { Injectable} from '@angular/core';
import { Headers, Http } from '@angular/http';
import { UserInfo } from './user-info.model';
@Injectable() //注入服務(wù)
export class ListsService{
private userInfo;
constructor(private http: Http) {
this.userInfo = new UserInfo();
}
//設(shè)置路由顯示的狀態(tài)
setUserInfo(v) {
this.userInfo.userInfo = v;
}
//獲取路由顯示的狀態(tài)
getUserInfo() {
return this.userInfo;
}
}
配置了service一定要在ngmodule中導(dǎo)入,這樣才能在此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">特價(jià)展示</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();
}
}
在詳情頁(yè)中通過改變狀態(tài)來改變頁(yè)面
@Component({
selector: 'app-detail',
template: `
<div>
詳情頁(yè){{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();
}
//組件銷毀時(shí)執(zhí)行
ngOnDestroy():void{
this.userInfo= this.listsService.setUserInfo(true);
}
}
好了,這樣就ok了。以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Angular 4.x 動(dòng)態(tài)創(chuàng)建組件
本篇文章主要介紹了詳解Angular 4.x 動(dòng)態(tài)創(chuàng)建組件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
Angular2利用組件與指令實(shí)現(xiàn)圖片輪播組件
這篇文章主要給大家介紹了Angular2中組件與指令的一個(gè)小實(shí)踐,利用組件和指令實(shí)現(xiàn)一個(gè)圖片輪播組件的相關(guān)資料,文中給出了詳細(xì)的介紹和示例代碼,需要的朋友可以參考學(xué)習(xí),下面來一起看看吧。2017-03-03
AngularJS使用ng-repeat遍歷二維數(shù)組元素的方法詳解
這篇文章主要介紹了AngularJS使用ng-repeat遍歷二維數(shù)組元素的方法,結(jié)合實(shí)例形式分析了AngularJS二維數(shù)組元素遍歷的相關(guān)操作技巧,需要的朋友可以參考下2017-11-11
Angular4.x通過路由守衛(wèi)進(jìn)行路由重定向?qū)崿F(xiàn)根據(jù)條件跳轉(zhuǎn)到相應(yīng)的頁(yè)面(推薦)
這篇文章主要介紹了Angular4.x通過路由守衛(wèi)進(jìn)行路由重定向,實(shí)現(xiàn)根據(jù)條件跳轉(zhuǎn)到相應(yīng)的頁(yè)面,這個(gè)功能在網(wǎng)上商城項(xiàng)目上經(jīng)常會(huì)用到,下面小編給大家?guī)砹私鉀Q方法一起看看吧2018-05-05
AngularJS ng-repeat數(shù)組有重復(fù)值的解決方法
不知道大家是否遇到過這個(gè)問題,在當(dāng)Angular.JS ng-repeat數(shù)組中有重復(fù)項(xiàng)時(shí),系統(tǒng)就會(huì)拋出異常,這是該怎么做?本文通過示例代碼介紹了詳細(xì)的解決方法,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-10-10
動(dòng)態(tài)創(chuàng)建Angular組件實(shí)現(xiàn)popup彈窗功能
這篇文章主要介紹了動(dòng)態(tài)創(chuàng)建angular組件實(shí)現(xiàn)popup彈窗,需要的朋友可以參考下2017-09-09
詳解利用Angular實(shí)現(xiàn)多團(tuán)隊(duì)模塊化SPA開發(fā)框架
本篇文章主要介紹了詳解利用Angular實(shí)現(xiàn)多團(tuán)隊(duì)模塊化SPA開發(fā)框架,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11
Angular5中狀態(tài)管理的實(shí)現(xiàn)
這篇文章主要介紹了Angular5中狀態(tài)管理的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09

