最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Angular5中状态管理的实现

来源:动视网 责编:小采 时间:2020-11-27 22:08:41
文档

Angular5中状态管理的实现

Angular5中状态管理的实现:前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的数据,同样,react中的redux和mbox也是,但遇到angular5却不知道了。 一年前使用过angular1.x做过项目,那时全局状态可以使用$rootscope,也
推荐度:
导读Angular5中状态管理的实现:前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的数据,同样,react中的redux和mbox也是,但遇到angular5却不知道了。 一年前使用过angular1.x做过项目,那时全局状态可以使用$rootscope,也


前面学习了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中状态管理的实现

Angular5中状态管理的实现:前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的数据,同样,react中的redux和mbox也是,但遇到angular5却不知道了。 一年前使用过angular1.x做过项目,那时全局状态可以使用$rootscope,也
推荐度:
标签: 中的 状态 实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top