Jquery自动完成 - 编程和硬编码响应

Jquery自动完成 - 编程和硬编码响应

问题描述:

我正在修改一些jquery自动完成代码。当前的代码工作正常,响应列表是以编程方式生成的,但我想在响应列表的顶部添加一个硬编码的“All Companies”,这将与响应列表中的其他条目一样起作用。这里是我一起工作的代码:Jquery自动完成 - 编程和硬编码响应

$(function() { 
    $("#report_generator_search").autocomplete({ 
     source: function(request, response) { 
      $.ajax({ 
       url: "lib/test.php", 
       dataType: "json", 
       type: "POST", 
       data: { 
        action: "search_test", 
        featureClass: "P", 
        style: "full", 
        maxRows: 24, 
        searchTerm: request.term 
       }, 
       success: function(f) { 
        response($.map(f, function(item) { 
         return { 
          label: item.company_name + ' ('+item.company_id+') ' + item.generator_address, 
          value: item.company_name, 
          company_id: item.company_id 
         } 
        }));   
       } 
      }); 
     }, 
     minLength: 1, 
    }); 

我曾尝试只需添加另一种反应,但不走:

response($.map(f, function(item) { 
         return { 
         label: "All Companies", 
         value: "All Companies", 
         company_id: "" 
        } 
        })); 

我试图预谋,这使“所有公司”顶部但按钮根本不起作用,像其他列表元素:

$('.ui-autocomplete').prepend('<li class="ui-menu-item" role="menuitem"><a class="ui-corner-all" tabindex="-1">All Companies</a></li>'); 

任何帮助,将不胜感激。谢谢。

您只能调用一次response()。您需要创建一个结果列表:

success: function(f) { 
    // Begin with your hard-coded choices 
    var staticChoices = [ 
     { 
      label: "All Companies", 
      value: "All Companies", 
      company_id: "" 
     } 
    ]; 

    // Parse downloaded choices 
    var dynamicChoices = $.map(f, function(item) { 
     return { 
      label: item.company_name + ' ('+item.company_id+') ' + item.generator_address, 
      value: item.company_name, 
      company_id: item.company_id 
     } 
    }); 

    // Combine the two :) 
    response(staticChoices.concat(dynamicChoices)); 
} 
+0

非常感谢!这很好用。 – user1519884 2012-07-12 16:10:19

+0

不客气。你可以点击接受我的答案吗? ;) – Scotty 2012-07-13 00:18:00