Angular HttpClient没有发送由getter提供的属性
创始人
2024-10-19 06:30:06
0

如果你使用Angular HttpClient发送HTTP请求时,遇到了由getter提供的属性没有被发送的问题,你可以尝试以下解决方法:

  1. 使用自定义的序列化器:创建一个自定义的序列化器,用来将对象转换成可以发送的形式。在这个序列化器中,你可以手动地获取并发送由getter提供的属性。以下是一个示例:
import { HttpClient, HttpParams, HttpParameterCodec } from '@angular/common/http';

class CustomEncoder implements HttpParameterCodec {
  encodeKey(key: string): string {
    return encodeURIComponent(key);
  }

  encodeValue(value: string): string {
    return encodeURIComponent(value);
  }

  decodeKey(key: string): string {
    return decodeURIComponent(key);
  }

  decodeValue(value: string): string {
    return decodeURIComponent(value);
  }
}

@Injectable()
export class CustomHttpClient {
  constructor(private http: HttpClient) {}

  get(url: string, params: any): Observable {
    const options = {
      params: new HttpParams({ encoder: new CustomEncoder() }).set('getterValue', params.getterValue)
    };

    return this.http.get(url, options);
  }
}

在上面的示例中,我们创建了一个名为CustomEncoder的自定义编码器,用来处理HTTP参数的编码和解码。然后,在CustomHttpClient中的get方法中,我们使用这个自定义编码器来创建HttpParams对象,并在其中设置了由getter提供的属性。

  1. 手动构建请求参数:如果你不想使用自定义的序列化器,你也可以手动构建请求参数,并在其中包含由getter提供的属性。以下是一个示例:
import { HttpClient, HttpParams } from '@angular/common/http';

@Injectable()
export class CustomHttpClient {
  constructor(private http: HttpClient) {}

  get(url: string, params: any): Observable {
    let httpParams = new HttpParams();
    httpParams = httpParams.set('getterValue', params.getterValue);

    const options = {
      params: httpParams
    };

    return this.http.get(url, options);
  }
}

在上面的示例中,我们创建了一个HttpParams对象,并在其中设置了由getter提供的属性。然后,在CustomHttpClient中的get方法中,我们将这个HttpParams对象作为请求参数的一部分。

相关内容

热门资讯

5分钟机巧!德州透视插件(透视... 5分钟机巧!德州透视插件(透视)总是真的是有辅助辅助(哔哩哔哩)1、点击下载安装,德州透视插件脚本分...
4分钟技法!aapoker怎么... 4分钟技法!aapoker怎么开辅助器(透视)其实真的是有辅助脚本(哔哩哔哩)aapoker怎么开辅...
2分钟大纲!wepoker怎么... 2分钟大纲!wepoker怎么发冤家牌(透视)一贯是真的有辅助神器(哔哩哔哩)1、wepoker怎么...
第十分钟技法!wepoker私... 第十分钟技法!wepoker私人局怎么玩(透视)竟然真的是有辅助辅助(哔哩哔哩)1)wepoker私...
第十分钟方式!哈糖大菠萝开挂(... 第十分钟方式!哈糖大菠萝开挂(透视)其实存在有辅助工具(哔哩哔哩)1、实时哈糖大菠萝开挂透视辅助更新...
三分钟机巧!wepoker科技... 三分钟机巧!wepoker科技辅助器(透视)果然有辅助安装(哔哩哔哩)1、上手简单,内置详细流程视频...
8分钟技法!wepoker辅助... 8分钟技法!wepoker辅助插件功能(透视)切实有辅助透视(哔哩哔哩)wepoker辅助插件功能辅...
第4分钟手段!wepoker好... 第4分钟手段!wepoker好友局透视(透视)都是有辅助开挂(哔哩哔哩)1、下载好wepoker好友...
2分钟要领!wpk透视辅助方法... 2分钟要领!wpk透视辅助方法(透视)一直有辅助教程(哔哩哔哩)1、金币登录送、破产送、升级送、活动...
第一分钟模块!wepoker透... 第一分钟模块!wepoker透视底牌脚本(透视)切实真的是有辅助辅助(哔哩哔哩)一、wepoker透...