1

我得到一个这样的 JSON 数组:

[{"type":"user","id":"12","name":"Name of User"},{"type":"group","id":"9","name":"Name of UserGroup"}]

后端返回一个带有名称、ID 和类型(用户或组)的 JSON 数组。

在输入到输入字段之前,有什么方法可以操作 id,例如

 type+"_"+id

?

实际上,我正在使用它来初始化 tokenInput:

$("input#id").tokenInput(apiURL+"search.php", {
                defaultValue:"User or User Group",
                hintText:"Fill in User or User Group name.",
                noResultsText:"nothing found.",
                searchingText:"Searching...",
                queryParam:"search",
                crossDomain:false,
                tokenLimit:5,
                preventDuplicates:true,
                minChars:3,
                resultsFormatter:function(item) {
                    return "<li><img src="+((item.type=="user") ? "contact" : "contact_group")+ ".png\"/>"+item.name+"</li>";
                }
            });

在 Rory McCrossan 的帮助下,我成功了。将 id 更改为 resultsFormatter 方法即可:

resultsFormatter:function(item) {
     if (item.id.indexOf("_") == -1)
     {
           item.id = item.type+"_"+item.id;
     }

     return "<li><img src="+((item.type=="user") ? "contact" : "contact_group")+ ".png\"/>"+item.name+"</li>";

}

“if (item.id.indexOf (...))” 是必要的,因为 tokenInput 会匹配条目,如果您搜索相同的字符串,则 id 已经具有 type+“_” 前缀并且会得到它第二次/第三次/……时间。

4

1 回答 1

1

试试这个:

resultsFormatter: function(item) {
    var itemId = item.type + "_" + item.id;
    return "<li id='" + itemId + "'><img src="+((item.type=="user") ? "contact" : "contact_group")+ ".png\"/>"+item.name+"</li>";
}
于 2012-05-29T12:32:27.633 回答