vue里localStorage可以直接用吗

在 Vue 项目里能够直接使用 localStorage,因为 localStorage 是浏览器提供的 Web Storage API 的一部分,它独立于 JavaScript 框架,所以可以在 Vue 项目的任何地方使用,包括组件的模板、script 标签内部,无论是 Vue 2 还是 Vue 3 都适用。下面分别介绍在 Vue 2 和 Vue 3 里使用 localStorage 的方法。

在 Vue 2 中使用 localStorage

保存数据到 localStorage

html 复制代码
<template>
  <div>
    <button @click="saveData">保存数据到 localStorage</button>
  </div>
</template>

<script>
export default {
  methods: {
    saveData() {
      const data = { message: '这是要保存的数据' };
      // 将对象转换为 JSON 字符串
      const jsonData = JSON.stringify(data);
      // 保存到 localStorage
      localStorage.setItem('myData', jsonData);
      console.log('数据已保存到 localStorage');
    }
  }
};
</script>

从 localStorage 读取数据

html 复制代码
<template>
  <div>
    <button @click="getData">从 localStorage 读取数据</button>
    <p v-if="data">读取到的数据: {{ data.message }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      data: null
    };
  },
  methods: {
    getData() {
      // 从 localStorage 读取数据
      const jsonData = localStorage.getItem('myData');
      if (jsonData) {
        // 将 JSON 字符串转换为对象
        this.data = JSON.parse(jsonData);
        console.log('从 localStorage 读取到数据:', this.data);
      } else {
        console.log('localStorage 中没有找到对应数据');
      }
    }
  }
};
</script>

删除 localStorage 中的数据

html 复制代码
<template>
  <div>
    <button @click="removeData">删除 localStorage 中的数据</button>
  </div>
</template>

<script>
export default {
  methods: {
    removeData() {
      // 删除 localStorage 中的指定数据
      localStorage.removeItem('myData');
      console.log('localStorage 中的数据已删除');
    }
  }
};
</script>

在 Vue 3 中使用 localStorage

保存数据到 localStorage

html 复制代码
<template>
  <div>
    <button @click="saveData">保存数据到 localStorage</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const saveData = () => {
  const data = { message: '这是要保存的数据' };
  const jsonData = JSON.stringify(data);
  localStorage.setItem('myData', jsonData);
  console.log('数据已保存到 localStorage');
};
</script>

删除 localStorage 中的数据

html 复制代码
<template>
  <div>
    <button @click="removeData">删除 localStorage 中的数据</button>
  </div>
</template>

<script setup>
const removeData = () => {
  localStorage.removeItem('myData');
  console.log('localStorage 中的数据已删除');
};
</script>

注意事项

localStorage 只能存储字符串类型的数据,所以在保存对象或数组时,需要先使用 JSON.stringify() 方法将其转换为 JSON 字符串,读取时再使用 JSON.parse() 方法将其转换回对象或数组。

localStorage 存储的数据会一直保留在浏览器中,除非手动删除,并且存储大小通常限制在 5MB 左右。

在使用 localStorage 时,要注意数据的安全性,避免存储敏感信息

相关推荐
叫我阿柒啊3 分钟前
Java全栈工程师的实战面试:从基础到微服务的全面解析
java·数据库·vue.js·spring boot·微服务·前端开发·全栈开发
暖木生晖5 分钟前
引入资源即针对于不同的屏幕尺寸,调用不同的css文件
前端·css·媒体查询
袁煦丞38 分钟前
DS file文件管家远程自由:cpolar内网穿透实验室第492个成功挑战
前端·程序员·远程工作
用户0137412843739 分钟前
九个鲜为人知却极具威力的 CSS 功能:提升前端开发体验的隐藏技巧
前端
永远不打烊42 分钟前
Window环境 WebRTC demo 运行
前端
风舞43 分钟前
一文搞定JS所有类型判断最佳实践
前端·javascript
coding随想44 分钟前
哈希值变化的魔法:深入解析HTML5 hashchange事件的奥秘与实战
前端
一树山茶1 小时前
uniapp在微信小程序中实现 SSE进行通信
前端·javascript
coding随想1 小时前
小程序中的pageshow与pagehide事件,HTML5中也有?揭秘浏览器往返缓存(BFCache)
前端
萌萌哒草头将军1 小时前
Rspack 1.5 版本更新速览!🚀🚀🚀
前端·javascript·vue.js