Vue3使用sessionStorage保存会话数据的实现方式

 更新时间:2025年01月03日 09:33:20   作者:JJCTO袁龙  
在前端开发中,我们常常需要在用户会话期间保存一些数据,这些数据在页面刷新或导航时依然需要存在,sessionStorage 是一种非常方便的方式来实现这一点,在这篇文章中,我们将探讨如何在Vue3应用中使用sessionStorage来保存会话数据,需要的朋友可以参考下

1. 什么是sessionStorage?

sessionStorage是Web Storage API的一部分,它用于在客户端存储数据,仅在一个会话期间有效。这意味着当用户关闭浏览器或当前标签页时存储的数据会被清空。

主要特点:

  • 数据只在同一会话窗口中可用。
  • 只在同一窗口或选项卡中可用,窗口或选项卡关闭后数据被清除。

2. 在Vue3中使用sessionStorage

在Vue3中使用sessionStorage保存会话数据非常简单。我们可以通过Vue的生命周期钩子函数来保存和获取这些数据。接下来,我们展示一个示例,演示如何在Vue3项目中实现这一功能。

假设我们正在构建一个简单的Vue3应用,用户在输入表单时,我们希望能够在会话期间存储用户的输入数据。

2.1 创建Vue3项目

npm install -g @vue/cli

然后,使用Vue CLI创建一个新的Vue3项目:

vue create vue-session-example

按照提示选择合适的配置,创建完成后进入项目目录:

cd vue-session-example
npm run serve

你应该能够看到默认的Vue3项目模板在浏览器中运行。

2.2 创建一个表单组件

接下来,我们创建一个表单组件,用于输入和保存数据。在src/components目录下新建一个文件SessionForm.vue

<template>
  <div>
    <h1>会话表单</h1>
    <form @submit.prevent="handleSubmit">
      <div>
        <label for="username">用户名:</label>
        <input
          type="text"
          id="username"
          v-model="username"
          @input="saveToSessionStorage"
        />
      </div>
      <div>
        <label for="email">邮箱:</label>
        <input
          type="email"
          id="email"
          v-model="email"
          @input="saveToSessionStorage"
        />
      </div>
      <button type="submit">提交</button>
    </form>
  </div>
</template>

<script>
export default {
  name: "SessionForm",
  data() {
    return {
      username: "",
      email: "",
    };
  },
  methods: {
    saveToSessionStorage() {
      sessionStorage.setItem("username", this.username);
      sessionStorage.setItem("email", this.email);
    },
    loadFromSessionStorage() {
      const storedUsername = sessionStorage.getItem("username");
      const storedEmail = sessionStorage.getItem("email");

      if (storedUsername) {
        this.username = storedUsername;
      }
      if (storedEmail) {
        this.email = storedEmail;
      }
    },
    handleSubmit() {
      alert(`提交成功: 用户名 - ${this.username}, 邮箱 - ${this.email}`);
    },
  },
  mounted() {
    this.loadFromSessionStorage();
  },
};
</script>

<style scoped>
form {
  display: flex;
  flex-direction: column;
  max-width: 300px;
  margin: auto;
}

div {
  margin-bottom: 10px;
}

button {
  margin-top: 10px;
}
</style>

2.3 在App.vue中导入并使用表单组件

我们在App.vue中导入并使用刚刚创建的SessionForm.vue组件:

<template>
  <div id="app">
    <SessionForm />
  </div>
</template>

<script>
import SessionForm from './components/SessionForm.vue';

export default {
  name: 'App',
  components: {
    SessionForm
  }
};
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

2.4 保存和加载会话数据

SessionForm.vue中,我们通过以下几个步骤实现sessionStorage的保存和加载功能:

  1. 在表单输入事件中调用saveToSessionStorage方法保存数据到sessionStorage
  2. 在组件挂载时调用loadFromSessionStorage方法从sessionStorage中加载数据。

具体代码已经在上面的SessionForm.vue中展示出来。

2.5 测试实现

运行项目,打开浏览器中的应用。输入一些数据到表单中,刷新页面,你会发现之前输入的表单数据依然存在,这证明我们的sessionStorage保存和加载数据的方法已经成功实现。

3. 总结

在这篇文章中,我们探讨了如何在Vue3项目中使用sessionStorage保存和加载会话数据。通过使用sessionStorage,我们可以在用户会话期间存储数据,提供更好的用户体验。

到此这篇关于Vue3使用sessionStorage保存会话数据的实现方式的文章就介绍到这了,更多相关Vue3 sessionStorage保存会话数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue 页面状态保持页面间数据传输的一种方法(推荐)

    Vue 页面状态保持页面间数据传输的一种方法(推荐)

    vue router给我们提供了两种页面间传递参数的方式,一种是动态路由匹配,一种是编程式导航,接下来通过本文给大家介绍Vue 页面状态保持页面间数据传输的一种方法,需要的朋友可以参考下
    2018-11-11
  • vue3+vite加载本地js/json文件不能使用require浅析

    vue3+vite加载本地js/json文件不能使用require浅析

    这篇文章主要给大家介绍了关于vue3+vite加载本地js/json文件不能使用require的相关资料,require 是属于 Webpack 的方法,在v3+vite的项目里面并不适用,需要的朋友可以参考下
    2023-07-07
  • Vue.js学习记录之在元素与template中使用v-if指令实例

    Vue.js学习记录之在元素与template中使用v-if指令实例

    这篇文章主要给大家介绍了关于Vue.js学习记录之在元素与template中使用v-if指令的相关资料,文中给出了详细的示例代码供大家参考学习,相信对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-06-06
  • vue使用nprogress加载路由进度条的方法

    vue使用nprogress加载路由进度条的方法

    这篇文章主要介绍了vue使用nprogress加载路由进度条的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • vue在自定义组件上使用v-model和.sync的方法实例

    vue在自定义组件上使用v-model和.sync的方法实例

    自定义组件的v-model和.sync修饰符其实本质上都是vue的语法糖,用于实现父子组件的"数据"双向绑定,下面这篇文章主要给大家介绍了关于vue在自定义组件上使用v-model和.sync的相关资料,需要的朋友可以参考下
    2022-07-07
  • 使用sessionStorage解决vuex在页面刷新后数据被清除的问题

    使用sessionStorage解决vuex在页面刷新后数据被清除的问题

    localStorage没有时间期限,除非将它移除,sessionStorage即会话,当浏览器关闭时会话结束,有时间期限,具有自行百度。本文使用的是sessionStorage解决vuex在页面刷新后数据被清除的问题,需要的朋友可以参考下
    2018-04-04
  • Vue中全局变量的定义和使用

    Vue中全局变量的定义和使用

    这篇文章主要介绍了vue中全局变量的定义和使用,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • 使用Vue-cli 3.0搭建Vue项目的方法

    使用Vue-cli 3.0搭建Vue项目的方法

    这篇文章主要介绍了使用Vue-cli 3.0搭建Vue项目的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 超全面的vue.js使用总结

    超全面的vue.js使用总结

    Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的。相比于Angular.js,Vue.js提供了更加简洁、更易于理解的API,使得我们能够快速地上手并使用Vue.js。下面这篇文章主要给大家介绍了关于vue.js使用的相关总结,需要的朋友可以参考借鉴。
    2017-02-02
  • Vue中props用法介绍

    Vue中props用法介绍

    这篇文章主要给大家分享的是 Vue中props用法介绍,​ 在Vue中通过props,可以将原本孤立的组件串联起来,也就是可以子组件可以接收父组件传递过来的data,下面我们一起进入文章看看内容的详细介绍吧,需要的朋友也可以参考一下
    2021-11-11

最新评论