Angular5中状态管理

作者: 老鼠AI大米_Java全栈 | 来源:发表于2018-09-01 17:35 被阅读716次

前面学习了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了。
若有疑问,请加群交流:654979292

相关文章

  • Angular5中状态管理

    前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的...

  • NgRx/Store 4 + Angular 5使用教程

    本文将会示范如何使用NgRx/Store 4和Angular5。@ngrx/store是基于RxJS的状态管理库,...

  • ionic3升级适配angular5

    昨天angular5和ionic3同时发布更新了,为了用上angular5的新特性,还是有必要踩下坑的,当然踩坑的...

  • Flutter中状态管理

    在flutter开发中,我们对State来进行管理,通过State的改变,来更新界面的刷新,状态管理分为两大类:1...

  • 记录

    ant design 布局 高度100% angular5 jsonp使用 httpclient service ...

  • Flutter初识状态管理

    Flutter中,管理状态的最常见的方法: Widget管理自身的状态 父Widget管理子Widget的状态 混...

  • Vue3.0实现todolist-Vue3.0定义状态管理

    定义状态管理 定义状态管理在src-store-index.js文件中把创建状态管理createStore从vue...

  • Vuex

    是什么? Vuex 是专门为Vue提供的状态管理工具 状态即数据 状态管理就是管理 Vue组件中的数据 内部机制:...

  • flutter中状态管理Provider

    1.1. 继承关系图 1.2. 各种Provider 1.2.1. 基础Provider 有点类似于替代 Stat...

  • Flutter中状态管理的理解

    一、状态管理认知 1、核心解耦 我理解的状态管理核心思想是解耦。 和别的框架一样,Flutter中的状态管理主要是...

网友评论

    本文标题:Angular5中状态管理

    本文链接:https://www.haomeiwen.com/subject/wnyuwftx.html