경량 데이터 형식 - JSON
오늘은 수학이 정말 참을 수가 없네요
생각을 바꿔서 프론트엔드에 대해 글을 써보겠습니다
오늘은 JSON에 대한 지식을 조금 적어보겠습니다
아주 오래전부터 XML은 인터넷에서 데이터를 전송하는 표준입니다
그러나 일반적으로 XML은 너무 번거롭다고 생각합니다
나중에 웹이 발전하면서
사람들은 JSON이 더 편리하다는 것을 알게 되었습니다. JavaScript 구문의 하위 집합으로 사용
JSON이 표준이 되었습니다
이제 모든 사람이 JSON을 통신용 데이터 형식으로 사용합니다
JSON 기본 구문
(JSON: JavaScript Object Notation, JavaScript object Representation)
JSON 구문은 크게 세 가지 유형의 값으로 구분됩니다.
간단한 유형의 값: 문자열을 나타낼 수 있습니다. , 숫자, 부울 값 및 null
객체: 순서가 지정되지 않은 키-값 쌍을 나타내는 복잡한 데이터 유형
배열: 복잡한 데이터 유형 , 정렬된 값 목록을 나타냄
JSON은 정의되지 않음을 지원하지 않으며 함수도 지원하지 않습니다
단순 유형 값
단일 기본 유형 값도 JSON으로 간주할 수 있습니다.
구문과 JavaScript는 동일합니다
주의할 점은 단 하나입니다
JavaScript에서는 문자열을 큰따옴표나 작은따옴표로 표현할 수 있습니다
단, JSON의 문자열 형식은 큰따옴표를 사용해야 합니다
객체
JSON은 JavaScript 구문의 하위 집합이므로
주로 차이점에 대해 이야기하겠습니다
먼저 일반적으로 사용되는 객체 리터럴 선언 형식을 살펴보세요
var man = { name: 'payen', sex: 'male', age: 19};
JSON의 JavaScript 객체는 속성에 따옴표를 추가할 수 있는지 여부를 결정합니다.
(일반 객체와 JSON 객체를 구별하기 위해 일반적으로 따옴표를 추가하지 않습니다) )
그러나 JSON 객체에서는 속성에 (큰따옴표) 따옴표를 추가해야 합니다.
위의 내용 객체는 JavaScript에서도 이와 같이 작성할 수 있으며 이는
var man = { "name": "payen", "sex": "male", "age": 19};
와 완전히 동일합니다. 위의 JSON으로 표현된 객체는
{ "name": "payen", "sex": "male", "age": 19}
입니다(JSON에는 변수의 개념도 없고 세미콜론도 없습니다)
물론 JSON에서 객체의 값도 객체가 될 수 있습니다
아무리 JSON은 복잡하므로 개체의 키(속성)를 큰따옴표로 묶어야 합니다.
배열
JavaScript에서는 엄밀히 말하면 배열이 개체에 속하지만
일반적으로 다르게 처리합니다.
배열 리터럴을 선언하는 일반적인 방법
var value = [123, 'abc', true];
JSON에도 동일한 구문이 있습니다.
[123, "abc", true]
다시 말하지만, JSON에는 변수와 세미콜론이 없습니다
일반적으로 JSON의 가장 바깥쪽 형태는 배열과 객체입니다
배열, 객체, 단순 타입 값을 통해 다양한 JSON 데이터를 구성할 수 있습니다. 형식
JSON 파싱 및 직렬화
JSON이 인기 있는 더 중요한 이유
는 유용한 객체로 파싱하기가 더 쉽다는 점입니다
JSON 객체
JSON 파서는 오래 전에 JavaScript의 eval()을 사용했습니다.
하지만 위험하고 악성 코드를 실행할 수 있음
ES5는 JSON 구문 분석 동작을 표준화합니다
전역 객체 JSON 정의
두 가지 메서드가 있습니다
stringify()
JavaScript 객체 –> JSON 문자열parse()
JSON 문자열 –> JavaScript 객체
물론 가장 기본적인 사용법은 다음과 같습니다.
변환할 변수를 매개변수로 전달합니다
예(항상 이 예가 사용됩니다)
var man = { 'name': "payen", <-- sex: "male", <-- "age": 19, "school": { "name": 'HUST', "sex": undefined, <-- "location": function(){} <-- } } var str = JSON.stringify(man); console.log(str); console.log(typeof str);
콘솔 출력을 살펴보겠습니다
JSON.stringify가 실제로 JSON 문자열을 반환하는 것을 볼 수 있습니다.
따옴표가 없습니다. JSON 문자열에서 큰따옴표로 묶인
작은따옴표 속성도 있고 속성 값은 정의되지 않습니다. 또는 함수의 속성이 자동으로 무시됩니다.
(프로토타입 멤버도 무시됩니다.)
JSON.stringify()는 객체의 정의되지 않은 함수(ES6 기호 포함)를 자동으로 무시하지만
배열은 다른
배열에는 객체가 없고 무자비하게 쫓아내지만 null을 반환합니다
console.log(JSON.stringify([123, undefined, null, function(){}]));
JSON.parse를 사용하여 JavaScript 객체로 복원할 수 있습니다
console.log(JSON.parse(str));
아래에서 살펴보겠습니다. 이 두 함수의 자세한 사용법을 살펴보세요
stringify 직렬화
객체를 직렬화할 경우 이 메소드는 두 개의 매개변수를 허용할 수도 있습니다
하나는 필터, 배열 또는 함수일 수 있습니다.
두 번째는 JSON 문자열
필터<의 들여쓰기를 지정하는 것입니다. 🎜>
배열 필터배열의 형태는 상대적으로 간단합니다. 원하는 개체 속성을 지정할 수 있습니다. 또는 위의 예
var str = JSON.stringify(man,['name','sex']); console.log(str);
반환된 값은 해당 키의 값입니다
함수가 정의되지 않은 값을 반환하면 속성이 무시됩니다
var str = JSON.stringify(man, function(key, value){ if(key == 'name'){ return 'abc'; } if(key == 'sex'){ return; } return value; }); console.log(str);
注意这里最后一定要写return value;
才能正常显示其他值
如果使用了switch语句就写default: return value;
缩进
空格填充
另一个参数可以填写数字指定缩进的空格数(最大缩进10)
var str = JSON.stringify(man, null, 4); console.log(str);
字符填充
我们也可以指定缩进字符
var str = JSON.stringify(man, null, "- - "); console.log(str);
toJSON()方法
可能有些时候stringify不够满足我们的需求
这时我们可以给对象定义toJSON()方法
(但仍然是调用stringify()方法)
返回自身的JSON的数据格式
原生Date对象有默认toJSON()返回日期字符串(同Date中方法toISOString()结果相同)
我们可以给我们的对象添加一个toJSON属性
var man = { ..., toJSON: function(){ return this.school; } } var str = JSON.stringify(man); console.log(str);
这里再多说一句
很多同学误认为toJSON()返回的是JSON字符串
其实不是的
toJSON()返回的应该是一个适当的值,然后由JSON.stringify()对其进行序列化
所以toJSON()是返回一个能够被字符串化的安全JSON值
下面我们来看看调用JSON.stringify()发生了什么
序列化对象顺序
如果对象有toJSON()并且能获得有效值,优先调用,否则返回对象本身
若有第二个参数,对上一步返回的对象应用过滤器
对上一步返回的每个值进行相应序列化
若有第三个参数,执行序列化
parse解析
JSON.parse也可以接受另一个参数,它是一个函数
类似于上面序列化中过滤器的过滤函数
它被称作还原函数,同样接受键和值作为参数
首先我现在我们例子中的对象添加一个方法
var man = { ..., releaseDate: new Date(2016,11,11) } var str = JSON.stringify(man); console.log(str);
我们看到,由于Date对象存在toJSON()
序列化之后调用了toJSON()
我们看到了这样的字符串
console.log(JSON.parse(str));
这样的数据不是我们想要的
这样的情况我们怎么处理呢?
答案是使用还原函数
可以这样做
var msg = JSON.parse(str,function(key, value){ if(key == 'releaseDate'){ return new Date(value); }else{ return value; } }) console.log(msg.releaseDate.getFullYear(), msg.releaseDate.getMonth(), msg.releaseDate.getDate());
这样我们就可以使用得到的时间数据了
小结
没想到写了这么多
JSON其实很简单
就是一个轻量级的数据格式
可以简化表示复杂数据结构的工作量
主要要掌握ES5的全局对象JSON中的两个方法JSON.stringify()和JSON.parse()
总结几个要记住的重点
JSON.stringify()
用于把JavaScript对象转换为JSON字符串
可填写额外两个参数-筛选数组/替换函数和指定缩进对象遇到undefined、function、symbol(ES6)会忽略
数组遇到undefined、function、symbol(ES6)会返回null
JSON.parse()
用于把JSON字符串转换为JavaScript对象
可填写额外一个参数-还原函数
以上就是轻量级数据格式——JSON的内容,更多相关内容请关注PHP中文网(www.php.cn)!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











golangWebSocket과 JSON의 결합: 데이터 전송과 파싱의 실현 현대 웹 개발에서 실시간 데이터 전송은 점점 더 중요해지고 있습니다. WebSocket은 양방향 통신을 달성하는 데 사용되는 프로토콜입니다. 기존 HTTP 요청-응답 모델과 달리 WebSocket을 사용하면 서버가 클라이언트에 데이터를 적극적으로 푸시할 수 있습니다. JSON(JavaScriptObjectNotation)은 간결하고 읽기 쉬운 데이터 교환을 위한 경량 형식입니다.

오래된 컴퓨터나 저가형 컴퓨터에 새 생명을 불어넣을 완벽한 Linux 배포판을 찾고 계십니까? 그렇다면, 당신은 올바른 장소에 왔습니다. 이 기사에서는 오래되거나 덜 강력한 하드웨어에 맞게 특별히 맞춤화된 경량 Linux 배포판에 대한 최고의 선택 사항 중 일부를 살펴보겠습니다. 그 이면의 동기가 노후화된 장치를 되살리는 것이든 단순히 예산에 맞춰 성능을 극대화하는 것이든 이러한 경량 옵션은 확실히 그 비용에 적합합니다. 경량 Linux 배포판을 선택하는 이유는 무엇입니까? 경량 Linux 배포판을 선택하면 여러 가지 이점이 있습니다. 그 중 첫 번째는 최소한의 시스템 리소스에서 최고의 성능을 얻을 수 있다는 것입니다. 따라서 처리 능력, RAM 및 저장 공간이 제한된 구형 하드웨어에 이상적입니다. 그 외에도 더 많은 리소스를 집약적으로 사용하는 경우

MySQL5.7과 MySQL8.0은 서로 다른 두 가지 MySQL 데이터베이스 버전입니다. 두 버전 사이에는 몇 가지 주요 차이점이 있습니다. 성능 개선: MySQL8.0은 MySQL5.7에 비해 성능이 일부 향상되었습니다. 여기에는 더 나은 쿼리 최적화 프로그램, 더 효율적인 쿼리 실행 계획 생성, 더 나은 인덱싱 알고리즘 및 병렬 쿼리 등이 포함됩니다. 이러한 개선 사항은 쿼리 성능과 전반적인 시스템 성능을 향상시킬 수 있습니다. JSON 지원: MySQL 8.0에는 JSON 데이터의 저장, 쿼리 및 인덱싱을 포함하여 JSON 데이터 유형에 대한 기본 지원이 도입되었습니다. 이를 통해 MySQL에서 JSON 데이터를 보다 편리하고 효율적으로 처리하고 조작할 수 있습니다. 트랜잭션 기능: MySQL8.0은 원자와 같은 몇 가지 새로운 트랜잭션 기능을 도입합니다.

PHP 배열을 JSON으로 변환하기 위한 성능 최적화 방법은 다음과 같습니다. JSON 확장 및 json_encode() 함수를 사용하여 문자 이스케이프를 방지하고 버퍼를 사용하여 JSON 인코딩 결과 캐싱을 고려합니다. JSON 인코딩 라이브러리.

C# 개발에서 XML 및 JSON 데이터 형식을 처리하려면 특정 코드 예제가 필요합니다. 최신 소프트웨어 개발에서는 XML과 JSON이 널리 사용되는 두 가지 데이터 형식입니다. XML(Extensible Markup Language)은 데이터를 저장하고 전송하는 데 사용되는 마크업 언어인 반면, JSON(JavaScript Object Notation)은 경량 데이터 교환 형식입니다. C# 개발에서는 XML 및 JSON 데이터를 처리하고 조작해야 하는 경우가 많습니다. 이 기사에서는 C#을 사용하여 이 두 가지 데이터 형식을 처리하고 첨부하는 방법에 중점을 둘 것입니다.

Golang에서 json.MarshalIndent 함수를 사용하여 구조를 형식화된 JSON 문자열로 변환합니다. Golang에서 프로그램을 작성할 때 구조를 JSON 문자열로 변환해야 하는 경우가 종종 있습니다. 이 과정에서 json.MarshalIndent 함수가 도움이 될 수 있습니다. 포맷된 출력. 아래에서는 이 기능을 사용하는 방법을 자세히 설명하고 구체적인 코드 예제를 제공합니다. 먼저 일부 데이터가 포함된 구조를 만들어 보겠습니다. 다음은 표시입니다

빠른 시작: JSON 파일을 읽는 Pandas 방법, 특정 코드 예제가 필요합니다. 소개: 데이터 분석 및 데이터 과학 분야에서 Pandas는 중요한 Python 라이브러리 중 하나입니다. 풍부한 기능과 유연한 데이터 구조를 제공하며, 다양한 데이터를 쉽게 처리하고 분석할 수 있습니다. 실제 애플리케이션에서는 JSON 파일을 읽어야 하는 상황에 자주 직면합니다. 이 기사에서는 Pandas를 사용하여 JSON 파일을 읽고 특정 코드 예제를 첨부하는 방법을 소개합니다. 1. 팬더 설치

Jackson 라이브러리의 주석은 JSON 직렬화 및 역직렬화를 제어합니다. 직렬화: @JsonIgnore: 속성 무시 @JsonProperty: 이름 지정 @JsonGetter: get 메서드 사용 @JsonSetter: set 메서드 사용 역직렬화: @JsonIgnoreProperties: @JsonProperty 속성 무시: 이름 지정 @JsonCreator: 생성자 사용 @JsonDeserialize: 사용자 정의 논리
