优化 Context 封装,写了个图片拖拽排序组件

2022-05-17

今天的工作任务,默认优先就是继续完善 SA 项目的发布页面了,参考了之前的“全局”Context 写法,我重新调整了它们的文件存储约定,将原有的两个 Hooks(useGlobalData / useGlobalContext)和一个 Context(GlobalContext) 合并在一个文件里面进行导出,更好地进行状态调整了。

为发布页面准备的新 Context 整了起来,文件导出 usePublishData(封装 useReducer),usePublishContext(封装 useContext)和 PublishContext 三个对象,并对昨天现有的组件进行修改,实现数据判断和修改。

除此之外,还封装了一个小小的图片拖拽排序组件,使用 onDragStart / onDragOver / onDrop 三个事件,再结合一句话的核心代码,获取第一次鼠标选中图片的索引值,以及鼠标放开时图片的索引值,就可以简单搞定。

const _data = [...data];
_data.splice(placedIndex, 0, _data.splice(currentDragIndex, 1)[0]);

除了 SA 项目,CL 项目也在继续铲屎,需要调整一个页面的数据筛选条件。后端那边的态度也极其不好,有一条接口的参数等他了 20 分钟才得到回复,“反馈意见”里面提到的参数他那边都没有加上,最后我还是以他那边已提供的给整在了页面上。

自从上午起来之后,天气有些变凉,身体马上就开始感到不适了,从轻微感冒到流鼻水,只用了半天时间。下班之后一直感到不爽,还是吃了点药。饭后和老妈去了趟公园走走(我妈骑车,我则是小跑过去),回来就没有写代码了,整理下笔记,明天继续吧。

发布产品界面
未知 烦躁
概览页 时间轴
奇趣音乐盒 技术源于 Kico Player
Emmm,这里是歌词君