抛掉kendoUI的MultiSelect,自己实现 DropDownList MultiSelect

  我们首先来看下kendoUI官方的下拉框多选:

 

  再来看看telerik RadControls的下拉框多选:

 

  很明显从展现形式上来看,第二种是优于第一种的,至少我是这么认为的 :-)

那我们就对DropDownList 进行扩展吧。在这里顺便提一个知识点,jQuery为开发插件提拱了两个方法

jQuery.fn.extend(object) 和jQuery.extend(object)

  至于他们的区别和使用,可以看看园友的这篇文章,

http://www.cnblogs.com/wyjgreat/archive/2011/07/19/2110754.html

  言归正传,继续完成刚刚要做的事情吧 :)

  1  (function ($) {
  2 
  3             var kendo = window.kendo,
  4                 ui = kendo.ui,
  5                 DropDownList = ui.DropDownList;
  6 
  7             var MultiSelectBox = DropDownList.extend({
  8 
  9                 init: function (element, options) {
 10 
 11                     options.template = kendo.template(
 12                         kendo.format('<input type="checkbox" /><span data-value="#= {0} #">#= {1} #</span>',
 13                             options.dataValueField,
 14                             options.dataTextField
 15                         )
 16                     );
 17 
 18                     DropDownList.fn.init.call(this, element, options);
 19                 },
 20 
 21                 options: {
 22                     name: "MultiSelectBox",
 23                     index: -1
 24                 },
 25 
 26                 _focus: function (li) {
 27                     var that = this
 28                     if (that.popup.visible() && li && that.trigger("select", { item: li })) {
 29                         that.close();
 30                         return;
 31                     }
 32                     that._select(li);
 33                 },
 34 
 35                 _select: function (li) {
 36                     var that = this,
 37                          current = that._current,
 38                          data = that._data(),
 39                          value,
 40                          text,
 41                          idx;
 42 
 43                     li = that._get(li);
 44 
 45                     if (li && li[0]) {
 46                         idx = ui.List.inArray(li[0], that.ul[0]);
 47                         if (idx > -1) {
 48 
 49                             //获取元素li中checkbox被选中的项
 50                             var selecteditems = $(that.ul[0]).find("input:checked").closest("li");
 51 
 52                             value = [];
 53                             text = [];
 54                             $.each(selecteditems, function (indx, item) {
 55                                 var obj = $(item).children("span").first();
 56                                 value.push(obj.attr("data-value"));
 57                                 text.push(obj.text());
 58                             });
 59 
 60                             that.text(text.join(", "));
 61                             that._accessor(value !== undefined ? value : text, idx);
 62                         }
 63                     }
 64 
 65                 },
 66 
 67                 value: function (value) {
 68                     var that = this,
 69                         idx,
 70                         valuesList = [];
 71 
 72                     if (value !== undefined) {
 73 
 74                         if (!$.isArray(value)) {
 75                             valuesList.push(value);
 76                         }
 77                         else {
 78                             valuesList = value;
 79                         }
 80 
 81                         $.each(valuesList, function (indx, item) {
 82                             if (item !== null) {
 83                                 item = item.toString();
 84                             }
 85 
 86                             that._valueCalled = true;
 87 
 88                             if (item && that._valueOnFetch(item)) {
 89                                 return;
 90                             }
 91 
 92                             idx = that._index(item);
 93 
 94                             that.select(idx > -1 ? idx : 0);
 95 
 96                         });
 97 
 98                     }
 99                     else {
100                         return that._accessor();
101                     }
102                 }
103 
104             });
105 
106             ui.plugin(MultiSelectBox);
107 
108         })(jQuery);

  而我们在使用的时候就像使用kendoUI其他控件一样

 <script type="text/javascript">

        $(document).ready(function () {
            var data = [
                { Text: "Test1", Value: "1" },
                { Text: "Test2", Value: "2" },
                { Text: "Test3", Value: "3" },
                { Text: "Test4", Value: "4" }
            ];

            $("#multiselect").kendoMultiSelectBox({
                dataTextField: "Text",
                dataValueField: "Value",
                dataSource: data
            });
        });

    </script>

<input id="multiselect" />

  效果如下:

  

  网上也有个解决方案,但它在使用的时候已不像kendoUI控件那样使用了,所以不推荐,倒是可以看看http://jsfiddle.net/bDvkQ/

 

posted @ 2013-08-01 23:10  Aulan  阅读(7204)  评论(2编辑  收藏  举报