首页 > 其他分享 >cookies、sessionStorage与localStorage在Vue中的使用

cookies、sessionStorage与localStorage在Vue中的使用

时间:2023-04-13 18:37:45浏览次数:39  
标签:cookies Vue 浏览器 sessionStorage vue cookie localStorage

目录

简介

  1. cookies 临时存储在客户端中,并且有过期事件,到过期时间会被自动清理。
  2. sessionStorage 临时存储在客户端中,关闭浏览器后就会清空。
  3. localStorage 永久存储在客户端中,只有在清空缓存或手工删除或代码删除后才会清空。

localStorage的使用

语法

// 将值写入到用户浏览器中
// 普通字符串可以直接写入
localStorage.setItem('存储在浏览器中的键', 存储在浏览器中的值)
// 如果是对象或者是数组,需要转换成json格式字符串
localStorage.setItem('存储在浏览器中的键', JSON.stringify('值'))

// 获取用户浏览器中的localStorage保存的值
localStorage.getItem('存储在用户浏览器中的键')  // 键是在setItem阶段定义的

// 清除浏览器中的localStorage的值
localStorage.clear()                              // 清除所有
localStorage.removeItem('存储在用户浏览器中的键')   // 按键清除,键是在setItem阶段定义的

示例

<template>
  <div class="home">
    <!--定义两个输入框,用于获取用户的用户名和密码-->
    <p><input type="text" v-model="username"></p>
    <p><input type="password" v-model="password"></p>
    <!--设置三个点击事件,一个是设置localStorage,一个是查看localStorage,一个是删除localStorage并绑定点击事件-->
    <p>
      <button @click="addLocalStorage">设置localStorage</button>
    </p>
    <p>
      <button @click="checkLocalStorage">查看localStorage</button>
    </p>
    <p>
      <button @click="delLocalStorage">删除localStorage</button>
    </p>
  </div>
</template>

<script>
export default {
  name: 'HomeView',
  data() {
    return {
      username: '',
      password: '',
      userinfo: {name: 'jason', age: 18}
    }
  },
  methods: {
    // 添加localStorage到用户浏览器中的事件
    addLocalStorage() {

      // value必须是字符串,如果是对象或者是数组,需要转换成json格式字符串
      localStorage.setItem('info', JSON.stringify(this.userinfo))

      // 正式环境中不可能将用户名密码放在里面的,有安全隐患,这里只是做演示使用
      localStorage.setItem('name', this.username)
      localStorage.setItem('pwd', this.password)
    },
    // 查看localStorage的事件
    checkLocalStorage() {
      var userinfo = localStorage.getItem('info')
      var username = localStorage.getItem('name')
      var password = localStorage.getItem('pwd')
      alert('userinfo:', userinfo, 'username:', username, 'password:', password)
    },
    // 删除用户浏览器中的localStorage
    delLocalStorage(){
      // 清除所有
      localStorage.clear()
      // 清除一个指定的键
      localStorage.removeItem('info')
    }
  }
}
</script>

显示效果如下
image

sessionStorage的操作

操作与localStorage大致相同

语法

// 将值写入到用户浏览器中
// 普通字符串可以直接写入
sessionStorage.setItem('存储在浏览器中的键', 存储在浏览器中的值)
// 如果是对象或者是数组,需要转换成json格式字符串
sessionStorage.setItem('存储在浏览器中的键', JSON.stringify('值'))

// 获取用户浏览器中的sessionStorage保存的值
sessionStorage.getItem('存储在用户浏览器中的键')  // 键是在setItem阶段定义的

// 清除浏览器中的sessionStorage的值
sessionStorage.clear()                              // 清除所有
sessionStorage.removeItem('存储在用户浏览器中的键')   // 按键清除,键是在setItem阶段定义的

示例

<template>
  <div class="home">
    <!--定义两个输入框,用于获取用户的用户名和密码-->
    <p><input type="text" v-model="username"></p>
    <p><input type="password" v-model="password"></p>
    <!--设置三个点击事件,一个是设置sessionStorage,一个是查看sessionStorage,一个是删除sessionStorage并绑定点击事件-->
    <p>
      <button @click="addSessionStorage">设置sessionStorage</button>
    </p>
    <p>
      <button @click="checkSessionStorage">查看sessionStorage</button>
    </p>
    <p>
      <button @click="delSessionStorage">删除sessionStorage</button>
    </p>
  </div>
</template>

<script>
export default {
  name: 'HomeView',
  data() {
    return {
      username: '',
      password: '',
      userinfo: {name: 'jason', age: 18}
    }
  },
  methods: {
    // 添加localStorage到用户浏览器中的事件
    addSessionStorage() {

      // value必须是字符串,如果是对象或者是数组,需要转换成json格式字符串
      sessionStorage.setItem('info', JSON.stringify(this.userinfo))

      // 正式环境中不可能将用户名密码放在里面的,有安全隐患,这里只是做演示使用
      sessionStorage.setItem('name', this.username)
      sessionStorage.setItem('pwd', this.password)
    },
    // 查看localStorage的事件
    checkSessionStorage() {
      var userinfo = sessionStorage.getItem('info')
      var username = sessionStorage.getItem('name')
      var password = sessionStorage.getItem('pwd')
      alert('userinfo:', userinfo, 'username:', username, 'password:', password)
    },
    // 删除用户浏览器中的localStorage
    delSessionStorage(){
      // 清除所有
      // sessionStorage.clear()
      // 清除一个指定的键
      sessionStorage.removeItem('info')
    }
  }
}
</script>
  • 下如图所示
    image

cookie的操作

vue中操作cookie不能直接操作,需要借助第三方工具:vue-cookie或vue-cookies或js-cookie,它们的使用方法不同

  1. 安装vue-cookie
cnpm install vue-cookie
  1. 导入使用vue-cookie
<script>
// 别名自定义即可
import 别名 from 'vue-cookie'
</script>

语法

import cookie from 'vue-cookie'

// 设置cookie
cookie.set('键', 值, 过期时间)  // 如果过期时间不填写,则关闭浏览器就会删除,时间是以天为单位
// 如果是对象或者是数组,需要转换成json格式字符串
cookie.set('存储在浏览器中的键', JSON.stringify('值'))

// 查询cookie
cookie.get('存储在浏览器中的键')
// 删除cookie
cookie.delete('存储在浏览器中的键')

示例

<template>
  <div class="home">
    <!--定义两个输入框,用于获取用户的用户名和密码-->
    <p><input type="text" v-model="username"></p>
    <p><input type="password" v-model="password"></p>
    <!--设置三个点击事件,一个是设置cookie,一个是查看cookie,一个是删除cookie并绑定点击事件-->
    <p>
      <button @click="addCookie">设置cookie</button>
    </p>
    <p>
      <button @click="checkCookie">查看cookie</button>
    </p>
    <p>
      <button @click="delCookie">删除cookie</button>
    </p>
  </div>
</template>

<script>
import cookie from 'vue-cookie'
export default {

  name: 'HomeView',
  data() {
    return {
      username: '',
      password: '',
      userinfo: {name: 'jason', age: 18}
    }
  },
  methods: {
    // 添加localStorage到用户浏览器中的事件
    addCookie() {

      // value必须是字符串,如果是对象或者是数组,需要转换成json格式字符串
      cookie.set('info', JSON.stringify(this.userinfo),1)

      // 正式环境中不可能将用户名密码放在里面的,有安全隐患,这里只是做演示使用
      cookie.set('name', this.username)
      cookie.set('pwd', this.password)
    },
    // 查看localStorage的事件
    checkCookie() {
      var userinfo = cookie.get('info')
      var username = cookie.get('name')
      var password = cookie.get('pwd')
      alert('userinfo:', userinfo, 'username:', username, 'password:', password)
    },
    // 删除用户浏览器中的localStorage
    delCookie(){
      // 清除一个指定的键
      cookie.delete('infor')
    }
  }
}
</script>
  • 如图所示
    image

vue-cookies

  1. 安装vue-cookies
cnpm install vue-cookies -S
  1. 导入vue-cookies,需要在main.js中引入
import cookies from 'vue-cookies'
Vue.use(cookies)

语法

前提是已经在main.js中引入了

this.$cookies.set(keyName, value,time,path,domain,secure)  //KeyName是cookie的键,value是对应的值,time为何时自动删除(默认单位是秒,可以用算式比如60*60),path为存放路径,domain为域名,secure为是否要以安全的方式传输

// vue-cookies的时间格式
this.$cookies.set('test', '{a:1,b:2}',-1)  //永不删除
this.$cookies.set('test', '{a:1,b:2}',60)  //一分钟后删除
this.$cookies.set('test', '{a:1,b:2}','10s')  //10秒后删除
this.$cookies.set('test', '{a:1,b:2}',new Date(2019,9,13).toUTCString())  //2019年10月13日删除,new Date月份设置是从0开始的
this.$cookies.set('username',response.data.username, '7d');  // 7天后删除

// 判断本地是否有此cookie
this.$cookies.isKey(keyName)

// cookie的获取
this.$cookies.get(keyName)   //KeyName就是设置的cookie的名字,vue-cookie会将cookie自动转为json对象格式

// cookie的删除
this.$cookies.remove(keyName)

示例

<template>
  <div class="home">
    <!--定义两个输入框,用于获取用户的用户名和密码-->
    <p><input type="text" v-model="username"></p>
    <p><input type="password" v-model="password"></p>
    <!--设置三个点击事件,一个是设置cookie,一个是查看cookie,一个是删除cookie并绑定点击事件-->
    <p>
      <button @click="addCookie">设置cookie</button>
    </p>
    <p>
      <button @click="checkCookie">查看cookie</button>
    </p>
    <p>
      <button @click="delCookie">删除cookie</button>
    </p>
  </div>
</template>

<script>
import cookies from 'vue-cookies'

export default {

  name: 'HomeView',
  data() {
    return {
      username: '',
      password: '',
      userinfo: {name: 'jason', age: 18}
    }
  },
  methods: {
    // 添加localStorage到用户浏览器中的事件
    addCookie() {

      // value必须是字符串,如果是对象或者是数组,需要转换成json格式字符串
      this.$cookies.set('info', JSON.stringify(this.userinfo))

      // 正式环境中不可能将用户名密码放在里面的,有安全隐患,这里只是做演示使用
      this.$cookies.set('name', this.username)
      this.$cookies.set('pwd', this.password)
    },
    // 查看localStorage的事件
    checkCookie() {
      var userinfo = this.$cookies.get('info')
      var username = this.$cookies.get('name')
      var password = this.$cookies.get('pwd')
      alert('userinfo:', userinfo, 'username:', username, 'password:', password)
    },
    // 删除用户浏览器中的localStorage
    delCookie() {
      // 清除一个指定的键
      this.$cookies.remove('infor')
    }
  }
}
</script>

js-cookie的使用

js-cookie的使用大致与vue-cookie相同,下面只列举不同的部分

  1. 引入js-cookie
import jsCookie from 'js-cookie'
Vue.prototype.$cookie = jsCookie;
  1. 设置cookie
this.$cookie.set('itemKey', 'itemValue', { expires: 7});
// 第三个对象是一个键值对,可以设置需要的cookie的属性
expires : 定义有效期。如传入Number,则单位为天,也可传入一个Date对象,表示有效期至Date指定时间。默认情况下cookie有效期截止至用户退出浏览器。
path : string,表示此 cookie 对哪个地址可见。默认为”/”。
domain : string,表示此 cookie 对哪个域名可见。设置后 cookie 会对所有子域名可见。默认为对创建此 cookie 的域名和子域名可见。
secure : true 或 false,表示 cookie 传输是否仅支持 https。默认为不要求协议必须为 https。
  1. 其它与vue-cookie的方法相同,不再列举

标签:cookies,Vue,浏览器,sessionStorage,vue,cookie,localStorage
From: https://www.cnblogs.com/smyz/p/17315879.html

相关文章

  • vue3微信公众号商城项目实战系列(1)开发环境准备
    项目忙完,这次上新,写一个前端系列,采用vue3来开发一个微信公众号商城。前言:1.微信公众号商城本质也是一个网站,由一个个网页组成,只不过这些网页运行在手机端,能响应手指的点击、长按、拖拽等操作。2.既然是网页,当然可以用3件套(js+html+css)来写,但象vue这样的前端框架比3件套更高效......
  • 使用vue+bpmn-js实现activiti的流程设计器__Vue.js
    https://www.vue-js.com/topic/5f6c4af84590fe0031e591ef完整代码见github:https://github.com/griabcrh/vue-activiti-demo适配activitiimportactivitiModdleDescriptorfrom'../js/activiti.json';this.bpmnModeler=newBpmnModeler({container:ca......
  • vue上传文件显示进度条,当上传完成后间隔一秒进度条消失
    <template><el-uploadclass="avatar-uploader"action="api/file/upload":show-file-list="false":before-upload="beforeAvatarUpload":on-progress="handleUploadProgress&q......
  • Vuex
    1.概念在Vue中实现集中式状态(数据)管理的一个Vue插件,对vue应用中多个组件的共享状态进行集中式管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信2.何时使用?多个组件需要共享数据时3.搭建vuex环境创建文件:src/store/index.js//引入vue......
  • Vue样式组件库
    常用样式库常用的Vue样式库如下组件库说明地址element目前只支持到vue2.x版本,不再更新https://element.eleme.cn/#/zh-CNelement-plus样式与element相同,开发都为了在vue3.x版本中使用而升级https://element-plus.gitee.io/zh-CN/vans主要针对移动端的UI......
  • Vue之插件的使用
    目录作用使用定义全局变量作用vue的插件的作用就是为了增强Vue,比如router,比如Vuex本质就是包含install方法的一个对象,install的第一个参数是vue,第二个及之后的参数是使用都要传递的数据,插件对象中的install方法会被vue自动调用。使用在Vue项目的src目录中创建目录plugi......
  • 在Django+Vue3+GraphQL的Blog例子代码中引入Element-Plus UI Framework
    Vue3的UIFramework中有Element-Plus、BalmUI、Quasar、PrimeVue、AntDesignVue等UIFramework.Element-Plus是Element-UI的Vue3版,Element-UI的使用人数的基数较大,Github上的Star数也较多,就选择了Element-Plus作为这个Blog项目的UIFramework.UIFramework的好处就是提供了......
  • 使用vue ui命令创建vue项目
    使用vueui创建项目时的几个选项1、什么是vueuivue3相比vue2多了一个创建项目的方式,那就是使用vueui的命令方式创建项目。vueui的实质就是使用vue官方图形化项目管理工具2、如何使用vueui创建vue项目或者直接选择第二个使用vue3的默认选项,我在这里介绍手动配置2.1......
  • vue中通过事件获取元素的值
    vue中通过事件获取元素的值原生js获取值<template><div><ul><li>姓名:<inputtype="text"id="name"/></li></ul><button@click="doSubmit()"class="submit">获取表单的......
  • 用quasar+vue3+组合式api VueRouter实现路由嵌套(二级路由)
    前言:本项目使用的是quasar创建,vue3的组合式api语法。部分语法不同,但不影响理解,修改语法后可以在vue2/选项式api项目中运行。效果图:文件目录结构和代码如下:   文中用到的标题栏数据如下:consttitles=ref([{name:"首页",path:"home",children:[]},{......