作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在向后端发送 HTTP 请求并接收数据。我通过可观察流传递数据,并使用异步管道直接在 HTML 模板中订阅它。但是,我有一个问题。因为,我想一次又一次地通过单击按钮发送多个请求,所以我希望可观察者不断将新值添加到数据流中,而不是完全替换以前的值。我怎样才能做到这一点?
这是我的代码:
TS
productsData$ = this.productService.getProduct(this.payload);
loadMore()
{
....
this.productsData$ = this.productService.getProduct(updatedpayload);
}
HTML
<div class = "grid" *ngIf="productsData$ | async as productsData">
<div class="p-col-12 p-md-6 p-lg-3" *ngFor = "let pData of productsData; let i = index">
...
如何在发送 HTTP 请求并将新值添加到现有值的同时保留可观察流中的先前值?
最佳答案
我同意这些评论。您可以创建一个缓存数组并利用它来返回以前的值。
private readonly previousProductsData = [];
readonly buttonTrigger$ = new BehaviourSubject('');
productsData$ = this.buttonTrigger$.pipe(
switchMap(()=> this.productService.getProduct(this.payload)),
tap((product)=> {
this.previousProductsData.push(product)
}),
map(()=> this.previousProductsData)
);
按钮点击可能如下所示:
loadMore()
{
....
this.productService.buttonTrigger$.next('');
}
关于Angular:保留可观察值的先前值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68952283/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!