如何解决是否可以将参数传递给使用let初始化的变量?
下面是我从现在开始学习的其中一个教程中使用的代码段。有人可以帮忙了解如何将'mediastate'参数传递给'notify'函数中的变量'transientListen'吗?
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;
解决方法
据我所知,“监听”功能由模块中的return语句调用。问题是,“监听”功能需要一个参数,否则为:transientListener =监听器; =>未定义。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。