实现本地存储函数useLocalStorage

 我们经常需要使用 LocalStorage API,一个好用的可组合函数封装将帮助我们更好地使用它,让我们开始吧 👇:

<script setup lang='ts'>

import { ref, watch } from "vue"

/**
 * Implement the composable function
 * Make sure the function works correctly
*/
function useLocalStorage(key: string, initialValue: any) {
  const value = ref(initialValue)
  watch(value,(val)=>{
    localStorage.setItem(key,val)
  },{
    immediate:true
  })
  return value
}

const counter = useLocalStorage("counter", 0)

// We can get localStorage by triggering the getter:
console.log(counter.value)

// And we can also set localStorage by triggering the setter:

const update = () => counter.value++

</script>

<template>
  <p>Counter: {
  { counter }}</p>
  <button @click="update">
    Update
  </button>
</template>

其中的watch可以修改为以下方式:

watchEffect(() => {
    localStorage.setItem(key, value.value)
})

// watchEffect自动添加了immediate:true

watchEffect:立即运行一个函数,同时响应式地追踪其依赖,并在依赖更改时重新执行。

watchEffect的特点可以查看watchEffect()和effectScope()-CSDN博客

相关推荐

  1. 实现本地存储函数useLocalStorage

    2024-01-11 18:02:01       40 阅读
  2. uniapp中使用LocalStorage实现本地存储缓存数据

    2024-01-11 18:02:01       22 阅读
  3. Vue 本地存储

    2024-01-11 18:02:01       29 阅读
  4. uniapp的本地存储

    2024-01-11 18:02:01       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-11 18:02:01       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-11 18:02:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-11 18:02:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-11 18:02:01       18 阅读

热门阅读

  1. bool和BOOL的区别

    2024-01-11 18:02:01       26 阅读
  2. LLaMA Efficient Tuning

    2024-01-11 18:02:01       34 阅读
  3. Redis的基本命令和数据类型

    2024-01-11 18:02:01       34 阅读
  4. QT第1天

    QT第1天

    2024-01-11 18:02:01      35 阅读
  5. 合泰HT32F65C40F 串口驱动 例:UART0 数据收发

    2024-01-11 18:02:01       39 阅读
  6. qemu dump dtb

    2024-01-11 18:02:01       34 阅读
  7. jsp页面 input传值提示不是有效数字

    2024-01-11 18:02:01       37 阅读
  8. IP版权交易里有哪些坑?合同和价格怎么定?

    2024-01-11 18:02:01       30 阅读
  9. Linux备忘手册

    2024-01-11 18:02:01       28 阅读