Autocomplete-combobox Slickgrid自定义编辑器不完全有效

时间:2012-08-27 21:26:50

标签: jquery jquery-ui autocomplete jquery-ui-autocomplete slickgrid

我正在尝试在最新版本的SlickGrid中创建自定义自动完成组合框编辑器。组合框的主要目的是根据用户输入的文本显示结果,还包括一个向下箭头链接按钮,使用户可以通过将空白参数传递给'autoComplete'函数来查看所有结果。这是link,你可以在SlickGrid中查看我想要创建的自定义编辑器。 (请忽略“显示基础选择”按钮)

我能够根据用户输入获得建议,并且还会在列字段的右侧放置一个小箭头链接按钮,该列字段应该显示[availableTags]数组中的所有项目。当我单击箭头时,它不会列出所有基本上没有响应的项目​​。但是,如果用户键入与列表中的某个项目匹配的内容,则表示窗口小部件已打开,单击箭头按钮后,它将关闭但不会显示所有项目的列表。 我想我在处理DOM时出错了。任何帮助将不胜感激。

以下是创建列的源代码。

    var columns = [
        {id: "TestAuto", name: "Auto Complete", field: "TestAuto", minWidth:100,width:150, editor: Slick.Editors.Auto}
      ];

以下是自定义编辑器代码:

$.extend(true, window, {
    "Slick": {
      "Editors": {
        "Auto": AutoCompleteEditor,
        "Text": TextEditor,
        "Integer": IntegerEditor,
        "Date": DateEditor,
        "YesNoSelect": YesNoSelectEditor,
        "Checkbox": CheckboxEditor,
        "PercentComplete": PercentCompleteEditor,
        "LongText": LongTextEditor,
        "Combo": ComboTest
      }
    }
  });
  var availableTags = [
                        "ActionScript",
                        "AppleScript",
                        "Asp",
                        "BASIC",
                        "C",
                        "C++",
                        "Clojure",
                        "COBOL",
                        "ColdFusion",
                        "Erlang",
                        "Fortran",
                        "Groovy",
                        "Haskell",
                        "Java",
                        "JavaScript",
                        "Lisp",
                        "Perl",
                        "PHP",
                        "Python",
                        "Ruby",
                        "Scala",
                        "Scheme"
                      ];

  function AutoCompleteEditor(args) {
     var $input;
     var defaultValue;
     var scope = this;
     var calendarOpen = false;



     this.init = function () {

       $input = $("<INPUT id='tags' class='editor-text' />");
       $input.width($(args.container).innerWidth() - 25);
       $input.appendTo(wrapper);


       $( "<a>" )
            .attr( "tabIndex", -1 )
            .attr( "title", "Show All Items" )
            .appendTo( wrapper )
            .button({
                icons: {
                    primary: "ui-icon-triangle-1-s"
                },
                text: false
            })
            .removeClass( "ui-corner-all" )
            .addClass( "ui-corner-right ui-combobox-toggle" )

            .click(function() {

                // close if already visible
                if ( $input.autocomplete( "widget" ).is( ":visible" ) ) {
                    $input.autocomplete( "close" );
                    return;
                }

                // work around a bug (likely same cause as #5265)
                $( this ).blur();

                // pass empty string as value to search for, displaying all results
                $input.autocomplete( "search", "" );

                $input.focus();
            });

       $input.focus().select();
       $input.autocomplete({
            source: availableTags
        });

     };


     this.destroy = function () {
       $input.autocomplete("destroy");
     };

     this.focus = function () {
       $input.focus();
     };

     this.loadValue = function (item) {
       defaultValue = item[args.column.field];
       $input.val(defaultValue);
       $input[0].defaultValue = defaultValue;
       $input.select();
     };

     this.serializeValue = function () {
       return $input.val();
     };

     this.applyValue = function (item, state) {
       item[args.column.field] = state;
     };

     this.isValueChanged = function () {
       return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue);
     };

     this.validate = function () {
       return {
         valid: true,
         msg: null
       };
     };

     this.init();
   }

1 个答案:

答案 0 :(得分:3)

我发布这个问题后不久,终于找到了解决方案。为了显示建议框中列出的所有项目,必须在输入的autoComplete定义中将minLength设置为0.

$input.autocomplete({
                delay: 0,
                minLength: 0, //has to be 0 to bring all items in case the search contains empty string.
                source: availableTags
            });

很抱歉,那些长期以来一直在寻找解决这类问题的方法。