1

因为我使用的 dgrid 对象比与 store 交互的本机 dojo 对象多,所以我想切换到 dstore 而不是 dojo.store.rest。
但是,当我使用dstore适配器进行实时搜索(FilteringSelect)时,查询参数以一种破坏我的 api 的方式进行了修改:例如,我输入“foo”,它会向

/api?name=match=foo*

但我想要:

/api?name=foo*

就像它与dojo/store/rest. 我认为它来自 dstore 中的 Filter 类。
有没有办法禁用这个过滤器?

4

2 回答 2

1

这是我处理这个问题的方法,以及设置我使用的一些默认值

define([
  'dojo/_base/declare',
  'dojo/query',
  'dstore/Rest'
],
function (declare, query, Rest) {

   var csrfHeader = query('meta[name="_csrf_header"]')[0].content,
       csrfToken = query('meta[name="_csrf"]')[0].content,
       headers = {
           'Content-Type': 'application/json; charset=utf-8',
           'Accept': 'application/json'
       };

    headers[csrfHeader] = csrfToken;


return declare('app.store.rest', [ Rest ], {

       sortParam: 'sort',
       rangeStartParam: 'offset',
       rangeCountParam: 'limit',
       ascendingPrefix: '%2B',
       descendingPrefix: '%2D',
       accepts: 'application/json',
       headers: headers,

       _renderFilterParams: function (filter) {
           var _filter = this.inherited(arguments);
           for(var i=0; i<_filter.length; i++) {
               _filter[i] = _filter[i].replace('match=', '').replace('*', '');
           }
           return _filter;
       }

   });
});
于 2017-10-15T23:32:45.053 回答
0

我找到了实现这种行为的方法,我必须添加 _renderFilterParams 的修改版本:

var store = new Rest({
    target: '/api',
    _renderFilterParams: function (filter) {
        var type = filter.type;
        var args = filter.args;
        if (!type)
            return [''];
        if (type === 'string')
            return [args[0]];
        return [encodeURIComponent(args[0]) + '=' + encodeURIComponent(args[1])];
    }
});
于 2015-09-14T18:39:14.223 回答