浏览器原理之本地存储

一 浏览器本地存储方式及使用场景

  1. Cookies:

    • 小段数据,由服务器发送到用户浏览器,浏览器将其存储并在以后的请求中回送到服务器。
    • 使用场景:会话管理(登录状态、用户偏好设置)、个性化(用户主题)、跟踪(分析用户行为)。
  2. LocalStorage:

    • 提供了一个在浏览器中存储数据的方式,数据无过期时间,直到显式地清除。
    • 使用场景:长期数据存储、网站偏好设置、无需每次都由服务器读取的大量数据。
  3. SessionStorage:

    • 类似于LocalStorage,但其存储的数据在页面会话结束时被清除(浏览器窗口关闭)。
    • 使用场景:会话级别的状态存储,如单个登录会话的用户界面状态。
  4. IndexedDB:

    • 一个允许你存储大量数据在用户浏览器中的低级API。支持事务、存储二进制数据等。
    • 使用场景:复杂的数据集合、离线应用程序、大规模数据处理、客户端数据库解决方案。

二 Cookie字段及其作用

  • Name:Cookie的名字。
  • Value:Cookie的值。
  • Domain:Cookie对哪个域是有效的。
  • Path:指定一个URL路径,只有路径匹配时,浏览器才会发送Cookie。
  • Expires/Max-Age:定义Cookie的过期时间。如果不设置,Cookie会在浏览器关闭时失效。
  • Secure:标记为Secure的Cookie只应通过被HTTPS协议加密过的请求发送给服务端。
  • HttpOnly:设置HttpOnly属性的Cookie不能通过JavaScript的Document.cookie API访问。

Cookie、LocalStorage、SessionStorage区别

  • 存储大小
    • Cookie:一般限制在4KB。
    • LocalStorage 和 SessionStorage:可以存储大约5MB的数据。
  • 生命周期
    • Cookie:可以设置过期时间,不设置则默认为会话结束时过期。
    • LocalStorage:数据没有过期时间,需要显式清除。
    • SessionStorage:数据仅在页面会话期间可用,窗口或标签页关闭后数据被清除。
  • 数据访问
    • Cookie:每次都会随HTTP请求发送到服务器,影响性能。
    • LocalStorage 和 SessionStorage:仅在客户端中访问,不与服务器通信。

三 IndexedDB的特点

  • NoSQL数据库:IndexedDB允许你存储和检索对象,是一个事务性数据库系统。
  • 支持大数据量存储:相比LocalStorage提供更大的存储容量。
  • 异步:操作IndexedDB的API是异步的,不会阻塞浏览器。
  • 支持事务:支持事务功能,可以进行错误处理和回滚。
  • 支持索引:可以创建对数据的索引,优化查询效率。

这些存储技术各有特点和适用场景,了解它们的差异和限制对于设计有效的前端存储策略非常重要。

相关推荐

  1. 浏览器原理本地存储

    2024-04-21 13:42:01       41 阅读
  2. 浏览器原理浏览器机制

    2024-04-21 13:42:01       40 阅读
  3. 浏览器原理 浏览器安全

    2024-04-21 13:42:01       41 阅读
  4. 浏览器原理浏览器同源策略

    2024-04-21 13:42:01       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-21 13:42:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-21 13:42:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-21 13:42:01       82 阅读
  4. Python语言-面向对象

    2024-04-21 13:42:01       91 阅读

热门阅读

  1. 续传查询SQL不规范导致漏数的问题

    2024-04-21 13:42:01       34 阅读
  2. linux的内存管理

    2024-04-21 13:42:01       28 阅读
  3. 提升用户体验的UUID设计策略

    2024-04-21 13:42:01       41 阅读
  4. 个人网站开(九)五系统前端react

    2024-04-21 13:42:01       30 阅读
  5. PyTorch项目实战开发教程:智能家居与IoT

    2024-04-21 13:42:01       76 阅读
  6. PostCSS概述

    2024-04-21 13:42:01       167 阅读
  7. Go中的HTTP请求处理概述

    2024-04-21 13:42:01       32 阅读
  8. Golang context 原理分析

    2024-04-21 13:42:01       98 阅读