#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 = слушатель; => не определено.