Можно ли передать аргумент переменной, инициализированной с помощью let ?

#javascript #variables #browser #arguments #matchmedia

#javascript #переменные #браузер #аргументы #matchmedia

Вопрос:

Ниже приведен фрагмент кода, используемый в одном из руководств, которые я изучаю сейчас. Может кто-нибудь, пожалуйста, помочь понять, как аргумент ‘mediastate’ может быть передан переменной ‘transientListen’ в функции ‘notify’?

 function createMediaListener(queries) {
  let transientListener = null;

  const keys = Object.keys(queries);

  const queryLists = keys.reduce((queryLists, key) => {
    queryLists[key] = window.matchMedia(queries[key]);
    return queryLists;
  }, {});

  const mediaState = keys.reduce((state, key) => {
    state[key] = queryLists[key].matches;
    return state;
  }, {});

  const notify = () => {
    if (transientListener != null) transientListener(mediaState);
  };

  const listeners = keys.reduce((listeners, key) => {
    listeners[key] = event => {
      mediaState[key] = event.matches;
      notify();
    };

    return listeners;
  }, {});

  const listen = listener => {
    transientListener = listener;
    keys.forEach(key => {
      queryLists[key].addListener(listeners[key]);
    });
  };

  const dispose = () => {
    transientListener = null;
    keys.forEach(key => {
      queryLists[key].removeListener(listeners[key]);
    });
  };

  const getState = () => mediaState;

  return { listen, dispose, getState };
}

export default createMediaListener;
  

Комментарии:

1. По-видимому, функция может быть назначена transientListener , создавая transientListener … функцию. Который может быть вызван с аргументом. Отсюда != null и предыдущая проверка; ожидается, что transientListener либо не задано, либо является функцией.

Ответ №1:

Насколько я понимаю, функция «listen» вызывается оператором return в модуле. Проблема в том, что для функции «прослушивания» требуется параметр, в противном случае: transientListener = слушатель; => не определено.