ServiceStack AutoQuery手动发送过滤器

时间:2017-02-28 14:18:54

标签: javascript servicestack autoquery-servicestack servicestack-autoquery

我们正在尝试使用JsonServiceClient手动构建自动查询请求。对于大多数操作而言,代码非常简单,但我不知道如何应用过滤器:

var client = new JsonServiceClient('https://my-app.azurewebsites.net');
var req = new dto.something();
req.pageSize = 10;
req.skip = 0;
req.take = 10;

我不知道如何发送过滤器?

以下是QueryBase的实现:

export class QueryBase {
    // @DataMember(Order=1)
    skip: number;

    // @DataMember(Order=2)
    take: number;

    // @DataMember(Order=3)
    orderBy: string;

    // @DataMember(Order=4)
    orderByDesc: string;

    // @DataMember(Order=5)
    include: string;

    // @DataMember(Order=6)
    fields: string;

    // @DataMember(Order=7)
    meta: { [index: string]: string; };
}

最后,是否有针对javascript / typescript客户端的ToPostUrl / ToGetUrl模拟?

1 个答案:

答案 0 :(得分:2)

TypeScript JsonServiceClient 0.0.23 中添加了对查询服务的新支持,这将允许您在查询服务时添加其他参数,例如:

var request = new dto.MyQuery();

client.get(request, {MyField:"TheFilter"})
    .then(r => {});

它还允许通过相对或绝对URL使用可选的queryString参数调用服务,例如:

client.get<Response>("/my-request/foo")

client.get<Response>("http://example.org/my-request/foo")

client.get<Response>("/my-request", { arg: "foo"})

ServiceStack只能为Explicit Conditions on your AutoQuery Request DTO生成类型属性。

在JavaScript / TypeScript中没有ToPostUrl / ToGetUrl等效,但有一些URL helpers in ss-utils可以帮助创建URL,例如:

var url = $.ss.createUrl("https://my-app.azurewebsites.net/myquery",   
    {pageSize:10,take:10,MyField:"TheFilter"});

$.getJSON(url, function(r) {
    console.log(r.Results);
});

类似的URL助手也可以在servicestack-client npm包中找到,例如:

import { combinePaths, nameof, appendQueryString } from 'servicestack-client';

let baseUrl = "https://my-app.azurewebsites.net";
let requestDto = new MyQuery();
requestDto.take = 10;

let pathInfo = combinePaths(baseUrl, "json", "reply", nameof(requestDto));
let url = appendQueryString(pathInfo, requestDto);
相关问题