90%的人封装Storage时忽略了一个点!你们知道封装的意义是啥吗?

开发
本文就是想让大家知道,封装 Storage 的时候,类型猜测是一个最基本的功能,有这个功能,使用者更方便、更无脑地使用​。

二次封装 Storage?

关于 Storage 的封装问题,其实都是老生常谈了,很多人都会在项目中去二次封装 Storage,为了让开发者能更加方便地去使用 localStore、sessionStorage。就比如下方,应该是很多人封装的案例,就是封装简单的 读取、写入,或者有 删除、清空:

我们为什么封装?

要不我们回过头来想一下,我们为什么要封装?其实封装无非就是为了两个目的:

  • 更好地统一维护
  • 使用者更方便、更无脑地使用

但是我觉得在一个大项目中以及紧急的开发进度中,使用者更方便、更无脑地使用才是封装的第一目的,所以想想刚刚的 LocalStorage 的封装,真的能让使用者更方便、更无脑地使用吗?

我就举个例子吧,我想存进去一个对象,我这么去存,可以吗?

显然是不行的,存进去的对象会被转成字符串 [object Object]:

所以我必须这么去存和取值,利用 JSON.parse、JSON.stringify 去转:

只有这么去做才能达到我的目的:

但是这样不觉得很麻烦吗?使用者更方便、更无脑地使用是封装的第一目的,显然这样只会让使用者徒增烦恼!!!

有的人就说了,可以把 JSON.parse、JSON.stringify 写在 useLocalStorage 中,但是这个方案只是针对 Object 而已,但是数据类型其实有多种:number、string、object、set、map、date 等等,你直接写在里面,不太合理,你得兼顾所有的数据类型才行!!

类型猜测逻辑

所以呢,你如果想要让使用者更方便、更无脑地使用,我们可以封装一套类型猜测逻辑。

首先我们必须准备一个函数,这个函数用来判断数据类型:

但是光是判断出类型还不够啊,我们还必须给每一种类型,准备一套 读取、存入 的策略:

最后只需要:

  • 判断类型
  • 获取类型对应的存取策略
  • 在存取的时候执行对应策略

我们现在可以来试试能不能达到目的:

显然已经达到我们想要的效果:

小结

当然, Storage 的封装不仅仅是类型猜测这么一个功能点!而且其实封装还有很多兜底的情况我这里没写出来,本文就是想让大家知道,封装 Storage 的时候,类型猜测是一个最基本的功能,有这个功能,使用者更方便、更无脑地使用。

责任编辑:赵宁宁 来源: 前端之神
相关推荐

2015-10-23 09:34:16

2024-08-01 17:34:56

Promiseaxios请求

2021-03-15 08:02:43

线性结构PriorityQue

2022-09-16 11:41:17

Spring代码

2020-08-07 16:18:38

JavaScriptC++Python

2018-06-05 09:13:47

2015-04-23 16:21:23

2021-08-26 21:55:38

DPU架构数据

2023-08-31 12:01:14

数据分析体系

2018-07-11 15:54:23

趋势互联网投资

2024-03-20 09:31:00

图片懒加载性能优化React

2015-09-21 14:22:43

2022-06-27 08:00:49

hook工具库函数

2015-06-02 09:51:40

iOS网络请求封装接口

2024-05-08 08:42:58

TypeScript函数文本颜色

2021-07-27 14:50:15

axiosHTTP前端

2020-03-12 08:28:09

文件Java开发

2022-07-20 09:06:27

Hook封装工具库

2020-03-16 17:20:02

异常处理Spring Boot

2022-10-17 08:03:47

封装vue组件
点赞
收藏

51CTO技术栈公众号