- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在后端使用 Angular 和 Restful C# API。我正在努力创建一个简单的购物车,并且一整天都在为此苦苦挣扎。当我在页面中调用添加到购物车方法时,逻辑首先检查该商品是否已在购物车中。如果是,它会增加计数并返回乘积,以便更新状态。如果产品不在购物车中,则会将产品添加到购物车中并返回产品对象以更新状态。
最初的调用错误,它把一切搞乱了 - 如果你能帮助我弄清楚发生了什么,我将永远感激不已!
C# 方法
[HttpGet("GetItem/{cartId}/item/{prodId}")]
public async Task<ProductViewModel> GetItem(string cartId, int prodId)
{
var prod = await _shopCartSvc.GetItem(cartId, prodId);
return prod;
}
[HttpGet("CreateItem/{cartId}/item/{prodId}")]
public async Task<ProductViewModel> CreateItem(string cartId, int prodId)
{
var prod = await _shopCartSvc.CreateItem(cartId, prodId);
return prod; // I stop it here to check my return values
}
在 Angular 形式中,我在产品卡组件中有以下逻辑
addToCart() {
console.log('addToCart');
this.cartSvc.addToCart(this.product)
.subscribe((p : Product) => {
this.product = p;
console.log('addToCart.done',p);
});
}
这会调用购物车服务 addToCart 公共(public)方法
addToCart(product: Product) {
console.log('cs.addToCart');
return this.updateItem(product);
}
这又调用私有(private) updateItem 方法来完成所有处理
private getItem(cartId: string, productId: number) {
console.log('getItem-productId', productId);
return this.http.get(this.getBaseUrl() + 'GetItem/'+ cartId +'/item/' + productId)
.pipe(
map((response: Product) => {
console.log('getItem-done', response);
return response
}),
catchError(this.handleError));
}
private createItem(cartId: string, productId: number) {
console.log('createItem');
return this.http.get(this.getBaseUrl() + 'CreateItem/'+ cartId + '/item/' + productId)
.pipe(
map((response: Product) => {
console.log('createItem-done', response);
return response
}),
catchError(this.handleError));
}
private updateItem(product: Product, amt: number = 1): Observable<Product> {
let cartId = this.getOrCreateCartId();
return this.getItem(cartId, product.id)
.switchMap(item => {
if (item == null) {
console.log('addItem');
// Create new item in cart
this.createItem(cartId, product.id)
.subscribe(item => {
console.log('addItem.done',item);
return of(item);
});
} else {
let total = item['quantity'] + amt;
if (total > 0) {
// Update qty of existing item in cart
item['quantity'] = total;
console.log('Cart Id',cartId,', UpdateItemQty to', total);
this.http.post(this.getBaseUrl() + 'UpdateItem/'+ cartId, item)
.take(1).switchMap( item => {
console.log('UpdateItem.done - newQty', item['quantity']);
return of(item);
});
} else {
// Qty 0 so remove
console.log('DELETE');
this.http.get(this.getBaseUrl() + 'RemoveItem/'+ cartId + '/item/' + item['id']);
return of (product);
} // end if
} // end if
}); // getItem - switchMap
}
在最初将商品添加到购物车期间会发生什么情况,它会抛出错误,但商品仍在添加中。根据日志消息,我得到
console.js:35 cs.addToCart
console.js:35 getItem-productId 1
console.js:35 getItem-done null
console.js:35 addItem
console.js:35 createItem
console.js:35 Global - Unhandled Error: TypeError: You provided 'undefined' where a stream was expected. You can provide an Observable, Promise, Array, or Iterable.
....
console.js:35 createItem-done {name: "Beagle", description: "", imageUrl: "Beagle.png", defaultTextColor: "Black", isPremiumProduct: false, …}
console.js:35 addItem.done {name: "Beagle", description: "", imageUrl: "Beagle.png", defaultTextColor: "Black", isPremiumProduct: false, …}
我是 Angular 的新手,我一生都无法弄清楚问题是什么。我可以进入 C# 后端并在 return 语句上停止它以查看返回的值。这是正确的类型和正确的值(value)观。当我在后端时,错误发生,当我继续流时,它会完成,但由于错误,我的对象状态不会更新。我得到的完整错误是:
console.js:35 Global - Unhandled Error: TypeError: You provided 'undefined' where a stream was expected. You can provide an Observable, Promise, Array, or Iterable.
at subscribeTo (subscribeTo.js:41)
at subscribeToResult (subscribeToResult.js:11)
at SwitchMapSubscriber.push../node_modules/rxjs/_esm5/internal/operators/switchMap.js.SwitchMapSubscriber._innerSub (switchMap.js:51)
at SwitchMapSubscriber.push../node_modules/rxjs/_esm5/internal/operators/switchMap.js.SwitchMapSubscriber._next (switchMap.js:41)
at SwitchMapSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at CatchSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber._next (Subscriber.js:77)
at CatchSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at MapSubscriber.push../node_modules/rxjs/_esm5/internal/operators/map.js.MapSubscriber._next (map.js:41)
at MapSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at MapSubscriber.push../node_modules/rxjs/_esm5/internal/operators/map.js.MapSubscriber._next (map.js:41)
at MapSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at FilterSubscriber.push../node_modules/rxjs/_esm5/internal/operators/filter.js.FilterSubscriber._next (filter.js:38)
at FilterSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at MergeMapSubscriber.push../node_modules/rxjs/_esm5/internal/operators/mergeMap.js.MergeMapSubscriber.notifyNext (mergeMap.js:84)
at InnerSubscriber.push../node_modules/rxjs/_esm5/internal/InnerSubscriber.js.InnerSubscriber._next (InnerSubscriber.js:15)
at InnerSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (Subscriber.js:54)
at XMLHttpRequest.onLoad (http.js:1534)
at XMLHttpRequest.wrapped (raven.js:376)
at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:423)
at Object.onInvokeTask (core.js:14051)
at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:422)
at Zone.push../node_modules/zone.js/dist/zone.js.Zone.runTask (zone.js:195)
at ZoneTask.push../node_modules/zone.js/dist/zone.js.ZoneTask.invokeTask [as invoke] (zone.js:498)
at invokeTask (zone.js:1744)
at XMLHttpRequest.globalZoneAwareCallback (zone.js:1781)
最佳答案
这里:
if (item == null) {
console.log('addItem');
// Create new item in cart
this.createItem(cartId, product.id)
.subscribe(item => {
console.log('addItem.done',item);
return of(item);
});
}
该项目已创建,因为您有 API 调用和订阅,但没有返回语句。订阅内的内容不算在内。如果你想返回一个流并执行一些副作用,你应该
if (item == null) {
console.log('addItem');
// Create new item in cart
return this.createItem(cartId, product.id)
.pipe(tap(item => {
console.log('addItem.done',item);
}))
}
关于javascript - Angular 服务调用 API 导致 switchmap 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58259793/
我不知道这之间是否有区别: Observable.pipe( switchMap((res) => { ... }),
我有以下代码 const mySource:Observable[]> (...) mySource.pipe( switchMap(arr=>forkJoin(arr)); ) 按预期工作,但
我正在尝试将 ViewModel 与某些 LiveData 一起使用,这些 LiveData 使用另一个 LiveData 的值。 为此,我尝试使用 Transformations.switchMap
我有以下组件: @Component({...}) export class AppComponent implements OnInit, OnDestroy { destroy$ = new
以下用例:用户可以加入 0...* 组。每个组都有一个 ID 并包含 0...* 个帖子。 我订阅了一个 Observable(以获取他加入的用户的组)并返回一个字符串数组(组 ID)。 const
我有 3 个端点返回即将发生的、当前的、过去的事件。我应该只显示 future 最远的那个。为了优化调用而不是一次调用所有端点。我编写了一个简单的 RxJs 流,我在其中调用第一个端点,如果它不返回数
我有一个表单,其中有一个按钮,可以使用表单的内容发送电子邮件。我想使用 switchmap,因为我想防止用户垃圾点击并创建大量 HTTP 请求,但我不知道该怎么做。 使用 switchmap 之前:
我正在尝试使用 switchMap 运算符切换可观察值: return this.db.list(`UserPlaces/${this.authData.auth.auth.currentUser.u
我尝试执行以下搜索: 我想根据第一个 id 搜索某些内容,这会返回一个 FirebaseListObservable。然后我尝试在 Observable 的 switchMap 函数中执行代码,因为搜
Observable .interval(2, TimeUnit.SECONDS) .switchMap(integer -> Observable
我遵循了教程 Angular Tour of Heroes 和其他一些教程,现在我正在尝试使用 Angular 2 构建应用程序。基本上,当我们正在监听 Subject 的变化时,我们可以等待几秒钟,
我有一个 Angular 应用程序,它向 Http 服务发出请求并在另一个 Http 服务上调用 switchMap。由于某种原因,switchMap 中的请求仅在第一次调用父调用时运行。否则父请求会
Angular 和 RxJS 的新手,试图稍微了解一下...我的应用程序对 UI 事件使用react,结果调用返回 Observable 的 HTTP 服务。我这样订阅: this.myXYZServ
我想解析一个 observable,但我不希望返回值替换管道中的先前值。有没有异步tap() ?我需要一个像 switchMap 这样的运算符(operator)但我想忽略返回。 of(1).pipe
我有一个 Observable,其中每个新值都应该引起一个 HTTP 请求。在客户端,我只关心最新的响应值;但是,我希望每个请求都能完成以进行监控/等。目的。 我目前拥有的是这样的: function
我有 HTTP 拦截器。在那个拦截器中,在我更改请求之前,我需要打开一个加载程序。 真正让我担心的是,我最终有很多 switchMap s。 为什么? 加载器是异步的 我还需要翻译从拦截器传递到加载器
这个问题已经有答案了: Angular 7 - nesting Observables (1 个回答) 已关闭 4 年前。 我正在尝试按照 Angular Routing 中有关如何获取路由参数的教程
我在使用 ngrx.store 和 states 时遇到了错误(?)。 在我调度新状态并且 reducer 返回新状态之后什么都没有发生。订阅不会收到任何错误消息。如果我删除 switchMap,代码
目前我有这段代码 this.save() .pipe(switchMap(() => this.unlock())) .subscribe(...); save 和unlock 实现是 pri
如果满足条件,我将尝试从 switchmap 返回一个值,但它返回的是拆分为单个字符的 console.log。因此,如果 Angular 色以 Buyer 身份返回,则它以 身份返回 console
我是一名优秀的程序员,十分优秀!