我正在尝试将breeze.js与sails.js结合使用。
因此,我使用的是微风json uriBuilder。我记录了req.query并得到了以下内容:
{ '{"where":{"name":"foo"},"orderBy":': { '"name"': '' } }要查询水线对象,我需要将其转换为如下格式:
{ where: { name: 'foo' }, sort: 'name' }我第一件事就是:
var queryString = JSON.parse(Object.keys(req.query)[0]);只要我只加入where子句就行了。但是有了更多的参数,我得到了这个格式奇怪的json对象。如何解析它以获得正确的对象?
解决方案:
不要解析他req.query。解析url并解析它。这样你就能得到风帆接受的机会。现在,去掉不支持的参数作为select,您就完成了。
var parsedUrl = urlUtils.parse(req.url, true);
var jsonQueryString = Object.keys(parsedUrl.query)[0];
var jsonQuery = JSON.parse(jsonQueryString);发布于 2015-02-19 21:19:45
问得好!我们还没有充分说明这一点,但基本思想是,有一个微风客户机npm包(https://www.npmjs.com/package/breeze-client),您可以使用它将传入的json查询解析为一个EntityQuery实例,然后您可以在那里查询EntityQuery并将其转换为您想要的任何服务器端语法,比如您的Sails。)
// req = the HTTP request object.
var resourceName = req.params.slug; // the HTTP endpoint
var entityQuery = breeze.EntityQuery.fromUrl(req.url, resourceName);
// you would write the transform to sails below.
var sailsQuery = tranformToSails(entityQuery);这正是我们在轻松中所做的事情--续写npm包,在这里,我们获取传入的req.query,并在上面的过程中创建一个“后缀”查询。
请参阅http://www.getbreezenow.com/sequelize-mysqlpostgressql-lite
https://stackoverflow.com/questions/28616078
复制相似问题