Как установить DIV видимой нагрузки с javascript - PullRequest
0 голосов
/ 25 января 2020

У меня есть эта страница, я хочу сделать первое описание карты для отображения загрузки. div id - это "firstitem", и я не могу обработать javascript для отображения загрузки (суб) контента.

(function (global, factory) {
  if (typeof define === 'function' && define.amd) {
    define(['jquery'], factory);
  } else {
    factory(jQuery);
  }
})(this, function ($) {
  var defaultSettings = {
    prefix: "imagelistexpander-"
  };

  var waitForFinalEvent = (function () {
    var timer = null;
    return function (callback, uniqueId) {
      if (timer) {
        clearTimeout(timer);
      }
      timer = setTimeout(callback, 500);
    };
  })();

  var imageListExpander = function (list, _settings) {
    var
      settings = $.extend({}, defaultSettings, _settings),
      $list = $(list),
      $items = $list.find('.' + settings.prefix + 'item'),
      $trigger = $list.find('.' + settings.prefix + 'trigger'),
      $closeTrigger = $list.find('.' + settings.prefix + 'trigger-close'),

      initialize = function () {
        $(window).bind('resize', resizeWindow);
        $trigger.bind('click', clickItem);
        $closeTrigger.bind('click', clickCloseTrigger);
      },
      resizeWindow = function () {
        waitForFinalEvent(function () {
          $items.filter('.active').each(function () {
            var
              $item = $(this),
              $expanderContents = $item.find('.' + settings.prefix + 'expander-contents'),
              $expander = $item.find('.' + settings.prefix + 'expander'),

              expanderHeight = $expanderContents.outerHeight();

            $item.css(
              'height',
              $item.find('.' + settings.prefix + 'contents').outerHeight() + expanderHeight
            );

            $expander.css('max-height', expanderHeight);
          });
        });
      },
      clickItem = function () {
        var $item = $(this).parents('.' + settings.prefix + 'item');
        `enter code here`

        if ($item.hasClass('active')) {
          hideItems($item);
        } else {
          showItem($item);
        }
      },
      clickCloseTrigger = function () {
        hideItems($items);
      },
      showItem = function ($item) {
        hideItems($item.siblings());

        var
          $expanderContents = $item.find('.' + settings.prefix + 'expander-contents'),
          $expander = $item.find('.' + settings.prefix + 'expander'),

          expanderHeight = $expanderContents.outerHeight();

        $item.addClass('active').css(
          'height',
          $item.find('.' + settings.prefix + 'contents').outerHeight() + expanderHeight
        );

        $expander.css('max-height', expanderHeight);
      },
      hideItems = function ($targetItems) {
        $targetItems = $targetItems.filter('.active');

        var $expanders = $targetItems.find('.' + settings.prefix + 'expander');

        $targetItems.each(function () {
          var $item = $(this);
          $item.css(
            'height',
            $item.find('.' + settings.prefix + 'contents').outerHeight()
          );
        });

        $targetItems.removeClass('active');
        $expanders.css('max-height', 0);
      };

    initialize();
  };

  $.fn.imagelistexpander = function (settings) {
    $(this).each(function () {
      imageListExpander(this, settings || {});
    });
  };

  return $;
});

(function (global, $) {
  $('.gallery-items').imagelistexpander({
    prefix: "gallery-"
  });
})(this, jQuery)
.gallery-expander {
  position: absolute;
  left: 0;
  right: 0;
  overflow: hidden;
  max-height: 0;
  -webkit-transition: max-height 500ms ease;
  -o-transition: max-height 500ms ease;
  transition: max-height 500ms ease;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="container-fluid">
  <ul class="gallery-items">
    <li class="gallery-item highlight-box ">
      <div class="gall">
        <div class="gallery-contents gallery-trigger hl-inner">
          <div class="thumbnail ">12121</div>
          <div class="title">Gallery Item</div>
        </div>
        <div class="gallery-expander" id="firstitem">
          <div class="gallery-expander-contents">
            <div class="gallery-trigger-close close">x</div>
            <div class="title">ytytytyt</div>
            <div class="contents">Lorem ipsum dolor</div>
          </div>
        </div>
      </div>
    </li>
  </ul>
</div>

Ответы [ 2 ]

0 голосов
/ 25 января 2020

Вы можете прослушать событие onload, используя либо vanilla JS, либо jQuery

. Вы хотите установить max-height в значение по умолчанию, чтобы показать элемент , поскольку ваш CSS с использованием max-height: 0 - это то, что скрывает его

Ваниль JS:

window.onload = () => {
  document.getElementById('firstitem').style.maxHeight = 'none';
};

jQuery:

$(window).on('load', () => {
  $('#firstitem').css('max-height', 'none');
});
0 голосов
/ 25 января 2020

Просто напишите этот код на вашей странице загрузки, это должно работать

  $('#firstitem').css('max-height',100);
...