Angular5中状态管理的实现

前面学习了vue,react 都有状态管理,如vue中的vuex是全局状态管理,在任何组件里都可以引用状态管理中的数据,同样,react中的redux和mbox也是,但遇到angular5却不知道了。

一年前使用过angular1.x做过项目,那时全局状态可以使用$rootscope,也可以使用服务Service实现,下面就用Service方式在angular5中实现下吧

先定义状态管理对象,需要存什么数据,自己定义

然后定义Service,如下

@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 { 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中使用了

`,styles:[` .lists a{ padding:0 10px; } .active{ color: #f60; } `] }) export class AppComponent { private userInfo; constructor(private listsService: ListsService) { this.userInfo= this.listsService.getUserInfo(); } }

在详情页中通过改变状态来改变页面

详情页{{id}}

`,})
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了。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)