Задать вопрос
vscnn
@vscnn

Почему функция из импортируемой библиотеки не видна?

Подключаю библиотеку для фильтрации элементов Isotope.
По какой-то причине встроенная функция matchesSelector не видна ниже в коде.
40e3f80c3f4440a49df71b8fd907583e.png
Хотя в демках все работает. Пользовался и раньше этой библиотекой, но не подключал её рекваером, и все работало.
Код:
const Isotope = require('isotope-layout');

const destinations = new Isotope('.destination-grid', {
  itemSelector: '.destination-grid-element',
  layoutMode: 'fitRows'
});

const destinationFiltersActive = 'destination-controls__filter-button_active';
const destinationFilters = document.querySelector('.destination-controls');
destinationFilters.addEventListener('click', (event) => {
  if(!matchesSelector(event.target, 'button')){
    return console.log('not matches');
  }
  const filterValue = event.target.getAttribute('data-filter');
  destinations.arrange({filter: filterValue});
});
const radioButtonGroup = (buttonGroup) => {
  buttonGroup.addEventListener('click', (event) => {
    if (!matchesSelector(event.target, 'button')) {
      return console.log('not matches');
    }

    buttonGroup.classList.toggle(destinationFiltersActive);
    event.target.classList.add(destinationFiltersActive);
  });
};
const buttonGroups = document.querySelectorAll('.destination-controls__filter-button');
for (let i = 0, len = buttonGroups.length; i < len; i++ ) {
  let buttonGroup = buttonGroups[i];
  radioButtonGroup(buttonGroup);
};


В gulpfile js таск выглядит так:
gulp.task('js', () => {
  browserify('./src/js/main.js')
    .transform(babelify)
    .bundle()
    .pipe(source('all.js'))
    .pipe(gulp.dest('./dist/scripts'))
    .pipe(connect.reload())
});


Если заменить matchesSelector на нативный matches, то видно что библиотека работает, но нужен именно matchesSelector для правильного выбора элементов. Подозреваю, что проблема в том как я подключаю скрипты. Что я делаю не так?

P.S — временно запустил ngrok, если вдруг кто-то захочет помочь: https://e8d5d86a.ngrok.io/
  • Вопрос задан
  • 338 просмотров
Подписаться 1 Оценить 1 комментарий
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
Wanted. Москва
от 250 000 до 400 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
27 дек. 2024, в 03:33
1500 руб./за проект
27 дек. 2024, в 02:41
50000 руб./за проект
26 дек. 2024, в 23:03
500 руб./в час