我们正在尝试使用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模拟?
答案 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);