помочь с jquery ui.helper [0] = ноль в IE6 - PullRequest
0 голосов
/ 30 марта 2010

Я пытаюсь использовать jquery для реализации интерфейса в стиле портлета / виджета, с 3 столбцами и перетаскиванием внутри и между ними. он работает почти полностью, за исключением проблемы, которая не работает в IE6

(function($) {
  $.fn.portlet = function() {
    return this.each(function() {
      $(this).sortable({
        connectWith: ['.portletColumn'],
        handle: 'h3',
        placeholder: 'drop',
        forcePlaceholderSize: true,
        start: StartDrag,
        stop: StopDrag
      });
    });
  };

  function StartDrag(event, ui) {
    try {
      //in ui.helper[0] is null and hence the issue
      //alert(ui.helper[0]);
      currentlyDraggedNode = this;
      alert(currentlyDraggedNode);
      ('.drop').css('height', jQuery(ui.helper[0]).outerHeight() + 'px');
      $('.portletColumn').css('background-color', '#eee');
    } catch (ex) { }
  }

  function StopDrag(event, ui) {
    try {
      $('.portletColumn').css('background-color', '#fff');
      UpdateOrder();
    } catch (ex) { }
  }

  function GetString(selector) {
    var querystring = "";

    $(selector).each(function() {
      var id = $(this).attr('id');

      if (id && id != '') {
        querystring += id + ';'
      }
    });

    return querystring;
  }

  function UpdateOrder() {
    var querystring = GetString('#col1 .portletColumn .portlet') + '|;' + GetString('#col2 .portletColumn .portlet') + '|;' + GetString('#col3 .portletColumn .portlet');
    $.get("/handlers/portlet.ashx?" + querystring);
  }
})(jQuery);

1 Ответ

1 голос
/ 30 марта 2010

Могу я спросить, почему вы используете jQuery(ui.helper[0]) вместо jQuery(ui.helper)? Весь код, который я вижу в исходном коде jQuery UI, ссылается на него таким образом

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...