Vue3 使用 Ts 泛型 封装本地存储

news2025/1/11 9:57:20

9a69fede8b2044a79dd834e3e48f20b4.png前期回顾f8e3cc1a0f694ac2b665ca2ad14c49d7.png   

NVM —— 你把我玩明白_彩色之外的博客-CSDN博客本文将学习 使用 NVM 管理node版本https://blog.csdn.net/m0_57904695/article/details/130670262?spm=1001.2014.3001.5501 

目录

 新建  \src\utils\storage-utils.ts

使用

泛型示例

泛型交换变量

泛型 string

泛型 对象

本文完!


👍 本文专栏:开发技巧  

 新建  \src\utils\storage-utils.ts

interface StorageUtilsInterface<T> {
  set(key: string, value: T): void;
  get(key: string): T | null;
  remove(key: string): void;
}

class LocalStorageUtils<T> implements StorageUtilsInterface<T> {
  set(key: string, value: T): void {
    localStorage.setItem(key, JSON.stringify(value));
  }

  get(key: string): T | null {
    const item = localStorage.getItem(key);
    if (item) {
      try {
        return JSON.parse(item);
      } catch (error) {
        console.error("Error parsing stored value:", error);
      }
    }
    return null;
  }

  remove(key: string): void {
    localStorage.removeItem(key);
  }
}

class SessionStorageUtils<T> implements StorageUtilsInterface<T> {
  set(key: string, value: T): void {
    sessionStorage.setItem(key, JSON.stringify(value));
  }

  get(key: string): T | null {
    const item = sessionStorage.getItem(key);
    if (item) {
      try {
        return JSON.parse(item);
      } catch (error) {
        console.error("Error parsing stored value:", error);
      }
    }
    return null;
  }

  remove(key: string): void {
    sessionStorage.removeItem(key);
  }
}

export { LocalStorageUtils, SessionStorageUtils };

使用


onMounted(() => {
  
  const localStorageUtils = new LocalStorageUtils<string>();

  // 设置localStorage
  localStorageUtils.set("username", "张坤");

  // 获取localStorage
  const username = localStorageUtils.get("username");
  console.log("username=====>", username); // "张坤"

  // 删除localStorage
  // setTimeout(() => {
  //   localStorageUtils.remove("username");
  // }, 2000);

  const sessionStorageUtils = new SessionStorageUtils<number>();

  // 设置sessionStorage
  sessionStorageUtils.set("age", 18);

  // 获取sessionStorage
  const age = sessionStorageUtils.get("age");
  console.log("age=====>", age); // 18

  // 删除sessionStorage
  // setTimeout(() => {
  //   sessionStorageUtils.remove("age");
  // }, 4000);
});

泛型示例

首先,什么是泛型?

泛型是一种模板机制,它允许在定义函数、类、接口等时使用类型参数(也称为类型变量),从而实现代码的复用。这里的类型参数可以是任何类型,在使用时可以传入具体的类型。

举个例子,假设我们要写一个函数来交换两个变量的值:

泛型交换变量

function swap(a: { value: any }, b: { value: any }) {
  const temp = a.value;
  a.value = b.value;
  b.value = temp;
}

let x = { value: 1 };
let y = { value: 2 };

swap(x, y);

console.log(x.value, y.value); // 输出 2, 1

上面的代码看起来没什么问题,但是有一个问题是:函数参数的类型都是any,也就是说这个函数可以交换任意类型的值,包括字符串、对象等等,这并不是我们想要的。

这时候,我们可以使用泛型来改进这个函数:

 function swap<T>(tuple: [T, T]): [T, T] {
    return [tuple[1], tuple[0]];
  }
  let tuple: [string, string] = ["张坤", "18"];
  console.log("交换前:", tuple);
  tuple = swap(tuple);
  console.log("交换后:", tuple);

输出:

交换前:Array [ "张坤", "18" ]

交换后:Array [ "18", "张坤" ]

在这个例子中,我们使用了类型参数<T>,并将其应用到函数参数上。这样,我们就可以指定要交换的值的类型。

泛型 string

接下来,再看看泛型接口StorageUtilsInterface<T>

这个接口定义了三个方法——set()get()remove(),它们都使用了类型参数<T>`,表示这些方法可以处理任意类型的值。比如,如果我们用这个接口存储一个字符串类型的值

const storage: StorageUtilsInterface<string> = new LocalStorageUtils();

storage.set('name', 'Tom');

const name = storage.get('name'); // name 的类型为 string | null

这里我们将<T>替换成了string,这样这个接口中的方法就会操作字符串类型的值了。

泛型 对象

如果要存储对象类型的值,可以将StorageUtilsInterface<T>中的类型参数<T>替换为对象类型。比如,假设我们有一个用户对象:

interface User {
  name: string;
  age: number;
}

const user: User = { name: 'Tom', age: 18 };

我们可以使用泛型接口StorageUtilsInterface<T>来存储这个对象:

const storage: StorageUtilsInterface<User> = new LocalStorageUtils();

storage.set('user', user);

const savedUser = storage.get('user'); // savedUser 的类型为 User | null

这里我们将<T>替换成了User,这样这个接口中的方法就会操作User类型的值了。在调用set()方法时,我们需要将user对象传给它,并且在调用get()方法后,返回的值的类型也会变成User | null,表示可能返回一个User类型的值或者null

需要注意的是,在这个例子中,User类型必须是一个可序列化的对象,即该对象可以转换为字符串并通过JSON.parse()方法解析回来。否则,在调用set()方法时会抛出异常。为了确保对象可序列化,我们可以为User类型添加一个[Serializable]标记,或者手动实现toJSON()fromJSON()方法。

本文完!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/529780.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在Linux系统中用vim编写第一个C语言之gcc编译器

文章目录 在Linux系统中用vim编写第一个C语言HelloWorld第一步 创建第二步 编写第三步&#xff0c;编译第四步 运行 gcc四步骤gcc常用选项 在Linux系统中用vim编写第一个C语言HelloWorld 第一步 创建 vim HelloWorld.c第二步 编写 #include<stdio.h>int main(){printf(…

Android Jsoup爬取网页数据及其局限性,接口爬取数据的思路

1.Jsoup jsoup 是一款Java 的HTML解析器&#xff0c;可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API&#xff0c;可通过DOM&#xff0c;CSS以及类似于jQuery的操作方法来取出和操作数据。 需求是需要获取某个网站上的排行榜数据&#xff0c;用作App展示&am…

【axios】后端未收到前端post传参

今天遇到过问题&#xff0c;前端post请求参数明明已经传过去了&#xff0c;可是后端说没收到&#xff0c;不知道后端大哥是不是故意搞我。 代码前端图如下↓ 代码 import axios from axios //对象形式 const val {pass:123,user:name}axios.post(/api/login, val).then(res>…

Vue3-黑马(十三)

目录&#xff1a; &#xff08;1&#xff09;vue3-router-动态路由3 &#xff08;2&#xff09;vue3-进阶router-动态菜单 &#xff08;3&#xff09;vue3-进阶-router-令牌-获取用户信息 &#xff08;1&#xff09;vue3-router-动态路由3 登录页面后&#xff0c;如果点击了…

Android技术探索与实践:从新功能体验到故障调试的全方位探索

目录 Android技术探索与实践&#xff1a;从新功能体验到故障调试的全方位探索 第一章&#xff1a;技术解析 Android平台的架构和工作原理 应用组件的生命周期和交互方式 Android开发中常用的设计模式和技术框架解析 第二章:产品新功能体验测评 深入了解最新发布的Androi…

【安卓源码】Binder机制5 -- Java层Framework Binder机制和 AIDL

图中红色代表整个framework层 binder架构相关组件&#xff1b; Binder类代表Server端&#xff0c;BinderProxy类代码Client端&#xff1b;图中蓝色代表Native层Binder架构相关组件&#xff1b;上层framework层的Binder逻辑是建立在Native层架构基础之上的&#xff0c;核心逻辑都…

shell编程:概述、脚本入门、变量、运算符、条件判断、流程控制、读取控制台、函数、正则表达式、文本处理工具、综合案例

第 1 章 Shell 概述 1&#xff09;Linux 提供的 Shell 解析器有 [atguiguhadoop101 ~]$ cat /etc/shells /bin/sh /bin/bash /usr/bin/sh /usr/bin/bash /bin/tcsh /bin/csh2&#xff09;bash 和 sh 的关系 sh&#xff1a;比较基础bash&#xff1a;功能更加强大&#xff0c;默…

三十四、Hybrid 接口用法解析

文章目录 前言交换机接口类型有哪些Hybrid 端口使用场景什么时候必须使用 Hybrid 一、Hybrid 特点二、Hybrid 当做 access和trunk使用三、Hybrid 特殊用法 前言 交换机接口类型有哪些 Access、trunk、Hybrid、qinq Hybrid 端口使用场景 接pc、服务器、接交换机、接路由器&a…

Linux守护进程

"忍耐的灵魂啊&#xff0c;安静地运转吧~" 我们先来看看这个场景。这是一个常见的基于TCP套接字的网络服务器&#xff0c;服务端接收客户端发送的消息&#xff0c;收到后并向echo回响给客户端。 对于Linux而言&#xff0c;终端只能有一个前台进程&#xff0c;这也是为…

行业唯一丨冠珠出席“中国企业社会责任高峰论坛”,并荣获人民日报社“ESG年度案例”

践行社会责任&#xff0c;推动品牌高质量发展。5月11日&#xff0c;由人民日报社指导、人民日报社经济社会部主办的“中国企业社会责任高峰论坛”在上海盛大举行。 本次论坛围绕乡村振兴、共同富裕、绿色低碳等重点议题进行深入研讨&#xff0c;邀请国家发展和改革委员会、商务…

教程硬货|微信小程序开发之基于vue的微信开发工具JS文件解读(一)

文章目录 1 前言2 前期准备3 微信开发者工具3.1 创建项目3.2 页面介绍 4 读懂Pages4.1 index.wxss4.2 index.wxml4.3 index.json4.4 index.js 5 logs6 小程序的主要文件6.1 app.js6.2 app.json 7 讨论 1 前言 鉴于前段时间出的第一篇记录安装Nodejs和HBuilderX搭建、部署微信小…

【C++】内存分区模型

目录 1、缘起 2、内存分区模型 2.1、程序运行前 2.2、程序运行后 3、总结 1、缘起 前几天学习完了 C 的 基础语法 知识点&#xff0c;现在终于要踏上学习 C 核心编程 的旅程了&#xff0c;期待沿途中所遇到的风景。 2、内存分区模型 C 程序在执行时&#xff0c;将内存大…

【Python Cookie 和代理 IP】零基础也能轻松掌握的学习路线与参考资料

一、Python Cookie 1、什么是Cookie&#xff1f; Cookie是一种在客户端保存数据的机制&#xff0c;服务器通过在HTTP响应头中添加Set-Cookie头实现。浏览器在接收到响应头中的Set-Cookie后&#xff0c;会将这个Cookie保存在本地。之后每次请求都会将本地保存的Cookie自动添加…

WPF插件之 - PropertyChanged.Fody插件的使用详解

总目录 文章目录 总目录一、PropertyChanged.Fody是什么&#xff1f;二、PropertyChanged.Fody的安装三、PropertyChanged.Fody的功能1. 特性1 实现属性通知的功能2 通知其他属性4 不进行属性通知3 指定属性更改时将调用的方法5 设置当前属性依赖的属性6 不检查是否相等7 DoNot…

lua:浅谈对元表和元方法的认识

前言 本篇在讲什么 浅谈对Lua元表和元方法的理解 本篇适合什么 适合初学Lua的小白 本篇需要什么 对Lua语法有简单认知 依赖Lua5.1的环境 依赖Sublime Text3编辑器 本篇的特色 具有全流程的图文教学 重实践&#xff0c;轻理论&#xff0c;快速上手 提供全流程的源码…

ETCD实现分布式锁

分布式锁具备特点 互斥性&#xff1a;在同一时刻&#xff0c;只有一个客户端能持有锁 安全性&#xff1a;避免死锁&#xff0c;如果某个客户端获得锁之后处理时间超过最大约定时间&#xff0c;或者持锁期间发生了故障导致无法主动释放锁&#xff0c;其持有的锁也能够被其他机制…

ANR实战案例 - FCM拉活启动优化

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 例如&#xff1a;第一章 Python 机器学习入门之pandas的使用 文章目录 系列文章目录前言一、Trace日志分析二、业务分析1.Firebase源码分析2.Firebase官方查看官方文档Dem…

数据压缩新利器!小精灵ELF助你高效存储与传输

存储空间不够用&#xff1f;网络传输太慢&#xff1f;想必每个人在生活中都会遇到这些问题。看着爆满的硬盘、焦急的等待数据的接受&#xff0c;更新设备&#xff1f;不是每个人都能承担这个成本。那不如尝试一下无损压缩&#xff1f; 为了减少存储空间的占用&#xff0c;提高…

《Netty》从零开始学netty源码(五十七)之ServerBootstrap.bind()

目录 ServerBootstrap.bind()initAndRegister()init()register()doBind0() ServerBootstrap.bind() 在第一篇的HelloWorld中通过ServerBootstrap.bind()方法绑定端口号并最终启动Netty的服务&#xff0c;服务端的bind过程如下&#xff1a; 上面的代码主要分成两部分&#xff0…

【P20】JMeter XPath提取器(XPath Extractor)

文章目录 一、准备工作二、测试计划 一、准备工作 百度&#xff1a;https://www.w3school.com.cn/example/xmle/cd_catalog.xml 进入网页后&#xff0c;右键检查或按F12&#xff0c;打开调试工具 如图&#xff0c;使用XPath提取器&#xff08;XPath Extractor&#xff09;获取…