0

我试图在我的预先输入中返回一个 json 对象,而不仅仅是一个查询。这个想法是在我的自动完成菜单中传递其他字段以帮助过滤结果。例如年份、品牌、型号、装饰。json 对象将包含过滤后的字段 id 和字段值。例如,在搜索 make 时,json 对象将包含过滤字段 id“年份”和值“2013”​​加上当前字段 id 和它的值。

目前这在下面有效,但只返回一个值。

 return $field.typeahead({
    replace: (uri, query) { 
       return extendURL(uri, "t:input": query);
    }
 }

这就是我正在尝试的方式。

<input id="year" value="2013"/>
<input id="make" filterBy="year" value="ford"/>
<input id="model" filterBy="ford" value="fusion"/>


 init = function(spec) {
        var $field = $("#" + spec.id),
                filterIdArray = [];

        if (typeof spec.filterId !== 'undefined') {
            filterIdArray = spec.filterId.split(',');
        }

 return $field.typeahead({
    replace: function(uri, query) {
       var params = {};
           params["t:jsonStringField"] = searchField(spec.id, query);
           params["t:jsonStringFilter"] = searchFilter(filterIdArray);

       var stringify = JSON.stringify(params);

       //I'm trying to pass back this stringified json object.  
       return extendURL(uri, stringify);
    }
  }

    //The current search input
    searchField = function(fieldId, query) {
        return {name: fieldId, value: query};
    };

    //Additional fields used to create where clause within searchField
    searchFilter = function(filterIdArray) {
        var array = [];

        //Field Id's and any fields being filtered by
        for (var i = 0; i < filterIdArray.length; i++) {
            var value = $("#" + filterIdArray[i]).val(),
                 name = filterIdArray[i];

            array.push({name: name, value: value});
        };

        return array;
    };

我最终得到以下错误。

“网络错误:500 内部服务器错误 - /TapDemo/sell/createlisting.year:autocomplete?category=aircraft&0={&1=%22&2=t&3=:&4=j&5=s&6=o&7=n&8=S&9=t&10=r&11=i&12= n&13=g&14=F&15=i&16=e&17=l&18=d&19=%22&20=:&21={&22=%22&23=n&24=a&25=m&26=e&27=%22&28=:&29=%22&30=y&31=e&32=a&33=r&34 =%22&35=,&36=%22&37=v&38=a&39=l&40=u&41=e&42=%22&43=:&44=%22&45=5&46=%22&47=}&48=,&49=%22&50=j&51=s&52=o&53=n&54 =S&55=t&56=r&57=i&58=n&59=g&60=F&61=i&62=l&63=t&64=e&65=r&66=%22&67=:&68=[&69=]&70=}"

有人知道我做错了什么吗?

4

1 回答 1

1

您需要做的是,将这些值作为 json 编码发送,并确保将数据解码为数组,这样您就可以处理这些值。

于 2013-09-16T04:29:54.487 回答