要在Angular应用中使用ngrx store来更新数据库更改,可以按照以下步骤进行操作:
import { createAction, props } from '@ngrx/store';
export const updateData = createAction('[Data] Update', props<{ newData: any }>());
import { createReducer, on } from '@ngrx/store';
import { updateData } from './actions';
export interface AppState {
data: any;
}
export const initialState: AppState = {
data: null
};
export const dataReducer = createReducer(
initialState,
on(updateData, (state, { newData }) => ({ ...state, data: newData }))
);
import { Component, OnInit } from '@angular/core';
import { Store } from '@ngrx/store';
import { updateData } from './actions';
import { DataService } from './data.service';
@Component({
selector: 'app-my-component',
templateUrl: './my-component.component.html',
styleUrls: ['./my-component.component.css']
})
export class MyComponent implements OnInit {
constructor(private store: Store, private dataService: DataService) { }
ngOnInit(): void {
// 订阅store中的数据
this.store.select('data').subscribe((data) => {
console.log('Data from store:', data);
});
// 在数据库更改时更新store中的数据
this.dataService.getData().subscribe((newData) => {
this.store.dispatch(updateData({ newData }));
});
}
}
以上是一个简单的示例,其中假设你已经创建了一个名为DataService的服务来获取数据库中的数据。在数据库更改时,你可以调用getData()
方法来获取新的数据,并将其更新到store中。
希望这可以帮助到你!