为什么String跟JSON不是同个东西?

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 很多人会误解JSON仅仅是序列化后的String,但这样的表述并不完全准确。JSON本质上是以字符串(String)形式表示的数据交换格式,但它不仅仅是一个字符串,而是具有特定语法和结构的字符串。很经常遇到的一个场景:后端:我给你返回了一段JSON,你转化下再遍历吧。

很多人会误解JSON仅仅是序列化后的String,但这样的表述并不完全准确。JSON本质上是以字符串(String)形式表示的数据交换格式,但它不仅仅是一个字符串,而是具有特定语法和结构的字符串。


很经常遇到的一个场景:


后端:我给你返回了一段JSON,你转化下再遍历吧。


等前端拿到的时候傻眼了。

1718959330675.jpg

前端:喂,真的是JSON?


后端: 千真万确!


那么JSON跟String怎么区分?

  1. 本质
  • String:是一个基本数据类型,用于表示一系列字符(例如文本、数字、符号等)。在前端中,字符串是用单引号(')、双引号(")或反引号(```)括起来的字符序列。
  • JSON:是一种轻量级的数据交换格式。它易于人阅读和编写,同时也易于浏览器解析和生成。在前端中,JSON对象通常被解析为对象、数组、字符串、数字、布尔值或null
  1. 用途
  • String:在前端开发中,字符串用于存储和表示文本数据。它们可以被用于各种目的,包括显示给用户、与其他服务器通信、处理文本数据等。
  • JSON:JSON主要用于存储和交换数据。它经常被用于在服务器和客户端之间传输数据。JSON数据可以很容易地被JavaScript解析,使其成为开发中非常流行的数据格式。
  1. 语法
  • String:在JavaScript中,字符串的语法相对简单,只需要用引号(“”)将字符序列括起来即可。
  • JSON:JSON的语法更加严格,因为它需要遵循特定的格式。例如,所有的字符串都必须用双引号括起来,对象的键也必须是双引号括起来的字符串。此外,JSON不支持JavaScript中的一些功能,如函数和undefined
  1. 转换
  • 在开发中,我们可以很容易地将JSON字符串解析为JavaScript对象(使用JSON.parse()方法),或者将JavaScript对象转换为JSON字符串(使用JSON.stringify()方法)。


下面是一个简单的例子来说明这种区别:

// 这是一个字符串  
let str = "Hello, World!";  
  
// 这是一个JSON字符串(注意双引号和对象的格式)  
let jsonStr = '{"name": "张三", "age": 30, "city": "上海"}';  
  
// 将JSON字符串解析为JavaScript对象  
let obj = JSON.parse(jsonStr);  
console.log(obj.name); // 输出 "张三"  
  
// 将JavaScript对象转换为JSON字符串  
let jsonStr2 = JSON.stringify(obj);  
console.log(jsonStr2); // 输出 '{"name":"张三","age":30,"city":"上海"}'

在这个例子中,str是一个字符串,而jsonStr是一个JSON字符串。通过JSON.parse()方法,我们可以将jsonStr解析为一个JavaScript对象obj。同样地,通过JSON.stringify()方法,我们可以将obj转换回一个JSON字符串jsonStr2


再来个标准的JSON对象跟String伪对象的区别:

const stringObj = "{'text': 'string obj'}";
const jsonObj = '{"text": "JSON Obj"}';

console.log(
    "stringObj: " + typeof stringObj
      )

      console.log(
    "jsonObj: " + typeof jsonObj
      )

      console.log(
    "jsonObj: ", JSON.parse(jsonObj)
)

    console.log(
    "stringObj: ", JSON.parse(stringObj)  // 报错,不是一个正规格式的JSON
)

1718959770177.jpg

这两个"JSON"看起来很相似,stringObj 是一个字符串字面量,其内容是一个看起来像 JSON 但实际上是用单引号包裹键和字符串值的非标准 JSON 格式。在 JavaScript 中,JSON 对象的键和字符串值通常使用双引号。


那么当后端返回一个string的伪JSON时,我们该怎么去解决呢

const strJson = <T>(
  str: string
): T => {

  if(typeOf(str) !== 'string') {
    return str as any
  }

  try {
    return JSON.parse(str)
  } catch {
    return (new Function(`return ${str}`)())
  }
}

接受一个参数,如果本身不是string则直接返回,如果 JSON.parse(str) 抛出异常(即 str 不是一个有效的 JSON 字符串),函数会捕获这个异常,并尝试通过创建一个新的函数并执行它来处理 str。有同学就会说这个直接执行str不安全,可以多加几道防护去过滤。


注意:可以使用eval代替new Function


我们拿上面例子2为例,看能不能处理这个伪JSON

  console.log(strJson(stringObj))
  console.log(strJson(jsonObj))

1718959845166.jpg

这当然是可以的啦,再也不怕拿到伪JSON


作者:大码猴

链接:https://juejin.cn/post/7379884568579555355

相关文章
|
2月前
|
JSON Java 关系型数据库
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
在Java中,使用mybatis-plus更新实体类对象到mysql,其中一个字段对应数据库中json数据类型,更新时报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
232 4
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
|
8月前
|
JSON 数据格式
使用 Gson 将 Map、List等转换为json string
使用 Gson 将 Map、List等转换为json string
223 0
|
8月前
|
SQL JSON Apache
Flink问题之嵌套 json 中string 数组的解析异常如何解决
Apache Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎。本合集提供有关Apache Flink相关技术、使用技巧和最佳实践的资源。
322 1
|
8月前
|
JSON fastjson Java
(fastjson)java 如何将String(字符串)与JSON互转
(fastjson)java 如何将String(字符串)与JSON互转
520 1
|
存储 JSON NoSQL
【Redis从头学-4】Redis中的String数据类型实战应用场景之验证码、浏览量、点赞量、Json格式存储
【Redis从头学-4】Redis中的String数据类型实战应用场景之验证码、浏览量、点赞量、Json格式存储
229 0
|
存储 JSON Go
Golang String字符串类型转Json格式
go的string字符串格式转json格式 确实有点麻烦,如果不知道json里面的类型好像就构建不了结构体了。
2490 0
|
JSON Android开发 数据格式
Android:解析Json异常 Expected a string but was BEGIN_OBJECT at
今天解析后端数据时,发现了这个报错:Expected BEGIN_OBJECT but was STRING at 看来是自己哪儿解析错误了。 因为数据的特殊性,后端返回的Json串里面可能还会有Json数据,可能嵌套了三次层,
|
JSON 小程序 PHP
解决php无法将string转换为json的办法
解决php无法将string转换为json的办法
202 0
解决php无法将string转换为json的办法
|
JSON 前端开发 安全
我们为什么推荐在Json中使用string表示Number属性值
在这篇简短的文章中,我将解释在使用JSON传输数据时,为什么浮点数或大十进制值应表示为字符串 。
我们为什么推荐在Json中使用string表示Number属性值
|
JSON fastjson Java
FastJSON 简介及其Map/JSON/String 互转
在日志解析,前后端数据传输交互中,经常会遇到 String 与 map、json、xml 等格式相互转换与解析的场景,其中 json 基本成为了跨语言、跨前后端的事实上的标准数据交互格式。应该来说各个语言中 解析 json 的库都一大片(具体 json 格式与三方库的介绍请见: http://www.json.org/json-zh.html ),比如 python 都集成在了内置库中,成为标准 API,今天我们要聊的是 java 中如何方便的使用 json 格式。
1947 0

热门文章

最新文章