首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Angular2如何在POST中隐藏空数组

Angular2如何在POST中隐藏空数组
EN

Stack Overflow用户
提问于 2016-09-13 07:58:17
回答 1查看 246关注 0票数 1

在我的过滤器中,我有产品列表。当有一些元素时,我只想发送这个数组。有可能吗?

请求函数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
getRecipes(page, pageSize, filters){
let body = JSON.stringify({ "size": pageSize, "page": page, "listOfFilters": filters});
let headers = new Headers({ 'Content-Type': 'application/json' });
let options = new RequestOptions({ headers: headers });

return this.http.post('http://localhost:8080/cookbook/recipe/filter',body,options)
        .map((res: Response) => res.json());}

过滤器类:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
export class Filter{
    products = new Array<String>();
    rating: {[key: string]:string} = {};
    level: {[key: string]:string} = {};
}

现在JSON看起来像这样:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{"size":10,"page":1,"listOfFilters":{"products":[],"rating":{"from":"1","to":"5"},"level":{"from":"1"
,"to":"5"}}}

我希望它看起来像(当产品列表为空时):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{"size":10,"page":1,"listOfFilters":{"rating":{"from":"1","to":"5"},"level":{"from":"1"
    ,"to":"5"}}}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-13 08:03:25

我不完全确定您希望最终结果是什么样子,但这是一个简单的if条件,您可以在其中利用delete

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
if (filters.products.length == 0) {
    delete filters.products;
}

let body = JSON.stringify({ "size": pageSize, "page": page, "listOfFilters": filters });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39464922

复制
相关文章

相似问题

在自制公式中创建别名

11

在公式标记中创建别名时出错

11

在计算中使用SQL别名创建其他别名

40

在SQL Server中创建别名

32

使用公式创建SQL Server表

11
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文