• webstorage


    浏览器本地存储 Web Storage

    HTML5新增了Web Storage本地存储属性

    浏览器本地存储包括两个对象:sessionStoragelocalStorage,它们都是 Storage 的实例对象。

    window.localStorage instanceof Storage // true
    
    • 1

    基本使用

    访问数据:getItem()

    添加、修改数据:setItem()

    删除数据:removeItem()

    清空数据:clear()

    获取给定位置的键名:key()

    // 以 localStorage 为例,sessionStorage 都一样
    // 添加数据
    localStorage.setItem('name', 'BruceBlog')
    localStorage.setItem('age', 2333)
    
    // 修改数据
    localStorage.setItem('age', 520)
    
    // 读取数据
    localStorage.getItem('age')
    
    // 删除数据
    localStorage.removeItem('name')
    
    // 清空数据
    localStorage.clear()
    
    // 遍历所有值,不知道是按什么顺序排列的
    for (let i = 0; i < localStorage.length; i++) {
      let key = localStorage.key(i)
      let value = localStorage.getItem(key)
      console.log(`key: ${key}, value: ${value}`)
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    注意事项

    只能够存储字符串,不是字符串的会调用 toString() 方法转成字符串。

    如果想要存储对象,需要使用 JSON.stringify() 转成 JSON 字符串再存储,以后再用 JSON.parse() 还原成对象。

    如果无法转成字符串,则会报错。比如 Symbol 类型的变量无法转成字符串。

    let obj = { book: 'HTTP', price: 46 }
    let obj2 = {}
    function fn() {}
    
    localStorage.setItem(obj, 'object') // '[object Object]': 'object'
    localStorage.setItem('func', fn) // 'func': 'function fn() {}'
    
    localStorage.setItem('info', JSON.stringify(obj)) // 'info': '{\"book\":\"HTTP\",\"price\":46}'
    
    localStorage.getItem(obj2) // 'object',obj2 会被转成 '[object Object]'
    
    localStorage.setItem('symbol', Symbol(666)) // Uncaught TypeError: Cannot convert a Symbol value to a string
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    容量

    目前业界基本上统一为5M

    作用域

    在这里插入图片描述
    这里的作用域指的是:如何隔离开不同页面之间的localStorage(总不能在百度的页面上能读到腾讯的localStorage吧,哈哈哈)。

    localStorage只要在相同的协议、相同的主机名、相同的端口下,就能读取/修改到同一份localStorage数据。

    sessionStorage比localStorage更严苛一点,除了协议、主机名、端口外,还要求在同一窗口(也就是浏览器的标签页)下。

    sessionStoragelocalStorage 对比

    sessionStorage 是跨会话存储机制,localStorage 是永久存储机制。

    作用时间:sessionStorage 在窗口关闭后就会失效,localStorage 是永久存储,除非手动通过 JS 删除或清除浏览器缓存。

    作用范围:sessionStorage 的数据只能在同源(协议域名端口号相同)、同一个窗口共享,localStorage 的数据在同源、不同窗口共享(同一个浏览器)

  • 相关阅读:
    论语第二篇-为政
    java通过kerberos认证并通过GSS-API获取kerberos服务票证
    java(1)
    hiveSql 各时段观看直播人数
    管理学复习重点
    (3) OpenCV图像处理kNN近邻算法
    项目01—基于nignx+keepalived双vip的负载均衡高可用Web集群
    [Android jni] Bitmap与Mat对象的相互转换
    Lightsail VPS 实例在哪些方面胜过 EC2 实例?
    mysql 数据库数据恢复 库被删了怎么恢复数据库
  • 原文地址:https://blog.csdn.net/h18377528386/article/details/126201038