useSessionStorage

具备响应式功能的 sessionStorage 状态

API

const [state, setState] = useSessionStorage(key, val)

Params

参数名描述类型默认值
key存进 sessionStorage 中的 keystring
val存进 sessionStorage 中的 val,会使用 JSON.stringify 进行序列化any

Result

参数名描述类型
state存进 sessionStorage 中的 val,从 sessionStorage 中取出时会进行 JSON.parse 反序列化, 只读DeepReadonly<Ref<T | null>>
setState更新 sessionStorage,同时 state 也会更新, 不传参数则等同于 removeItem(Val?: T) => void

Example

将数据持久化到 sessionStorage 中

sessionStorage中的值:

刷新页面能拿到存在 sessionStorage 中的状态

Code

<template>
  <p>将数据持久化到 sessionStorage 中</p>
  <p>sessionStorage中的值: {{ state }}</p>
  <p>刷新页面能拿到存在 sessionStorage 中的状态</p>
  <input v-model="value" />
  <button @click="update(value)">update</button>
  <button @click="update()">remove</button>
</template>

<script>
import { useSessionStorage } from 'vue-compositions'
import { ref } from 'vue'
export default {
  setup() {
    const [state, update] = useSessionStorage('test', 'test')
    const value = ref(state.value)
    return {
      state,
      value,
      update
    }
  }
}
</script>