Skip to content

Latest commit

 

History

History
executable file
·
77 lines (64 loc) · 1.89 KB

useLocalStorage.md

File metadata and controls

executable file
·
77 lines (64 loc) · 1.89 KB

useLocalStorage

Vue function that provides way to read, update and delete a localStorage key

Reference

interface StorageOptions {
  isParsing: boolean
  serializer?: SerializerFunction
  deserializer?: DeserializerFunction
}
function useLocalStorage(
  key: string,
  options?: StorageOptions,
  runOnMount?: boolean
): {
  item: Ref<any>
  getItem: () => void
  setItem: (newVal: any) => void
  removeItem: () => void
}

Parameters

  • key: string the localStorage key you wish to get/set/remove
  • options: StorageOptions
    • isParsing: boolean whether to enable parsing the localStorage key value or not, false by default
    • serializer: SerializerFunction a custom serializer, JSON.stringify by default
    • deserializer: DeserializerFunction a custom deserializer, JSON.parse by default
  • runOnMount: boolean whether to get the localStorage key on mount or not, true by default

Returns

  • item: Ref<any> the localStorage key value, it can be null, a string or a JSON object/array
  • getItem: Function get the localStorage key value
  • setItem: Function set the localStorage key value
    • newVal: any: the value to set, can be a string or an object/array
  • removeItem: Function delete the localStorage key

Usage

<template>
  <div>
    <div>Item: {{ item }}</div>
    <button @click="getItem">Get item</button>
    <button @click="setItem('Value here')">Set item</button>
    <button @click="removeItem">Remove item</button>
  </div>
</template>

<script lang="ts">
  import Vue from 'vue'
  import { useLocalStorage } from 'vue-use-kit'

  export default Vue.extend({
    name: 'UseLocalStorageDemo',
    setup() {
      const { item, getItem, setItem, removeItem } = useLocalStorage(
        'i_love_local_storage'
      )

      return {
        item,
        getItem,
        setItem,
        removeItem
      }
    }
  })
</script>