码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 18-JSON和浏览器数据存储


    文章目录

      • JSON
        • 一、JSON介绍
        • 二、JSON的两个方法
          • 1. 把js的对象或数组转化为json字符串
          • 2. 把接收到的后端的json字符串转换成js对象或数组
      • 本地存储和会话存储
        • 一、区别
        • 二、操作本地存储、会话存储的方式
          • 1. 所有操作对象的方式都适用
          • 2. 现成操作存储的api

    JSON

    一、JSON介绍

    json格式的文本,是所有编程语言都能识别的,在所有编程语言中都是同一个语法格式

    元素的值可以是number,string(双引号),null,bollean,array,obj

    json格式的文件主要用于前后端交互来传递数据。

    为什么使用json格式传递数据?

    • json格式体积小,一般把json叫做轻量级的数据交换格式(早期使用XML格式)
    • 所有语言都能识别json格式
    • 便于解析
    {
        "name":"lucy",
        "age":12,
        "like":["sleep","eat"],
        "vip":false,
        "family":{
            "mother":"韩梅梅",
            "father":"李雷",
            "pet":"dog"
        },
        "sister":null
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    二、JSON的两个方法

    1. 把js的对象或数组转化为json字符串

    语法:JSON.stringify(js对象或数组)

    返回值:json字符串

    const data = {
        "name":"lucy",
        "age":12,
        "vip":false,
    };
    const jsonStr = JSON.stringify(data);
    console.log(jsonStr);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    2. 把接收到的后端的json字符串转换成js对象或数组

    语法:JSON.parse(json字符串)

    返回值:js对象或数组

    const jsonStr = '{"name":"lucy"}';
    const data = JSON.parse(jsonStr);
    console.log(data)
    
    • 1
    • 2
    • 3

    本地存储和会话存储

    本地存储 localStorage 和会话存储 sessionStorage 是浏览器里面的一个存储空间,
    同一个域名下的不同页面可以共享同一个存储空间。

    如:
    同是file:// 开头的文件可以共享一个存储空间,
    同是http://127.0.0.1:xxxx/ 开头的文件可以同享一个存储空间

    一、区别

    本地存储会一直存储在浏览器中,除非手动删除

    会话存储只要关闭浏览器,就会被浏览器自动删除

    它们的操作方法是一样的,只是存在的时间不同

    console.log(localStorage);
    console.log(sessionStorage);
    
    • 1
    • 2

    二、操作本地存储、会话存储的方式

    1. 所有操作对象的方式都适用
    // 增加
    localStorage.name = "lucy";
    // 删除
    delete localStorage.name;
    // 修改(重新赋值)
    localStorage.name = "poly";
    // 查询
    console.log(localStorage.name);
    // 注意:存储到本地存储键和值都必须是字符串格式,如果不是,会强制转换
    localStorage.like = {name:"lucy",age:12};
    localStorage.family = ["小张","小李"]
    // 如果一定要存储对象和数组,可转换为json字符串再存储
    localStorage.like = JSON.stringify({name:"lucy",age:12});
    localStorage.family = JSON.stringify(["小张","小李"]);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    2. 现成操作存储的api
    // 新增:localStorage.setItem(key,value)
    localStorage.setItem("age",12);
    // 删除: localStorage.removeItem(key)
    localStorage.removeItem("name");
    // 新增一个相同的key就是修改
    localStorage.setItem("age",18);
    // 获取:localStorage.getItem(key)
    console.log(localStorage.getItem("like"))
    // 清空:localStorage.clear()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    注意:

    • 键和值都是字符串,如果传入的不是字符串,会被强制转换
    • 同源下的本地存储内容可以共享
    • 同源下的键是唯一的
  • 相关阅读:
    面试时,公司的什么表现让你一看就知道不靠谱?
    按摩软件仿东郊到家系统开发,上门预约系统;
    UE4中抛体物理模拟UProjectileMovementComponent
    Masked Image Training for Generalizable Deep Image Denoising 论文阅读笔记
    基于leetcode的算法训练:Day4
    操作系统实验(5)—— 页面淘汰算法模拟实现与比较
    MySQL(case when then end, update)
    Redis常见命令
    使用burp抓包时出现问题
    南美委内瑞拉市场最全分析开发攻略,收藏一篇就够了
  • 原文地址:https://blog.csdn.net/qq_41570386/article/details/127911221
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号