栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

窗口大小调整-React + Redux

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

窗口大小调整-React + Redux

好问题。我想在我的商店中使用用户界面。减速器的外观可能如下所示:

const initialState = {    screenWidth: typeof window === 'object' ? window.innerWidth : null};function uiReducer(state = initialState, action) {    switch (action.type) {        case SCREEN_RESIZE: return Object.assign({}, state, {     screenWidth: action.screenWidth });    }    return state;}

动作很漂亮。(

SCREEN_RESIZE
是一个常量字符串。)

function screenResize(width) {    return {        type: SCREEN_RESIZE,        screenWidth: width    };}

最后,将其与事件侦听器连接在一起。我将以下代码放在初始化

store
变量的地方。

window.addEventListener('resize', () => {    store.dispatch(screenResize(window.innerWidth));});

媒体查询

如果您的应用使用屏幕大小的更二进制视图(例如,大/小),则您可能更喜欢使用媒体查询。例如

const mediaQuery = window.matchMedia('(min-width: 650px)');if (mediaQuery.matches) {    store.dispatch(setLargeScreen());} else {    store.dispatch(setSmallScreen());}mediaQuery.addListener((mq) => {    if (mq.matches) {        store.dispatch(setLargeScreen());    } else {        store.dispatch(setSmallScreen());    }});

(这次我将省略动作和Reducer代码。很明显它们看起来是什么样子。)

这种方法的一个缺点是商店可能用错误的值初始化,并且我们依靠媒体查询在商店初始化后设置正确的值。缺少将媒体查询推入reducer文件本身的过程,我不知道解决此问题的最佳方法。欢迎反馈。

更新

现在我考虑了一下,您可以通过执行以下操作来解决此问题。(但是请注意,我尚未对此进行测试。)

const mediaQuery = window.matchMedia('(min-width: 650px)');const store = createStore(reducer, {    ui: {        largeScreen: mediaQuery.matches    }});mediaQuery.addListener((mq) => {    if (mq.matches) {        store.dispatch(setLargeScreen());    } else {        store.dispatch(setSmallScreen());    }});

更新二: 最后一种方法的缺点是

ui
对象将替换整个
ui
状态,而不仅仅是
largeScreen
字段。初始
ui
状态的任何其他内容都会丢失。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/636488.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号