오늘은 수학이 정말 참을 수가 없네요
생각을 바꿔서 프론트엔드에 대해 글을 써보겠습니다
오늘은 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)!

JavaScript는 1995 년에 시작하여 Brandon Ike에 의해 만들어졌으며 언어를 C로 실현했습니다. 1.C Language는 JavaScript의 고성능 및 시스템 수준 프로그래밍 기능을 제공합니다. 2. JavaScript의 메모리 관리 및 성능 최적화는 C 언어에 의존합니다. 3. C 언어의 크로스 플랫폼 기능은 자바 스크립트가 다른 운영 체제에서 효율적으로 실행하는 데 도움이됩니다.

JavaScript는 브라우저 및 Node.js 환경에서 실행되며 JavaScript 엔진을 사용하여 코드를 구문 분석하고 실행합니다. 1) 구문 분석 단계에서 초록 구문 트리 (AST)를 생성합니다. 2) 컴파일 단계에서 AST를 바이트 코드 또는 기계 코드로 변환합니다. 3) 실행 단계에서 컴파일 된 코드를 실행하십시오.

Python 및 JavaScript의 미래 추세에는 다음이 포함됩니다. 1. Python은 과학 컴퓨팅 분야에서의 위치를 통합하고 AI, 2. JavaScript는 웹 기술의 개발을 촉진하고, 3. 교차 플랫폼 개발이 핫한 주제가되고 4. 성능 최적화가 중점을 둘 것입니다. 둘 다 해당 분야에서 응용 프로그램 시나리오를 계속 확장하고 성능이 더 많은 혁신을 일으킬 것입니다.

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.

예, JavaScript의 엔진 코어는 C로 작성되었습니다. 1) C 언어는 효율적인 성능과 기본 제어를 제공하며, 이는 JavaScript 엔진 개발에 적합합니다. 2) V8 엔진을 예를 들어, 핵심은 C로 작성되며 C의 효율성 및 객체 지향적 특성을 결합하여 C로 작성됩니다.

JavaScript는 웹 페이지의 상호 작용과 역학을 향상시키기 때문에 현대 웹 사이트의 핵심입니다. 1) 페이지를 새로 고치지 않고 콘텐츠를 변경할 수 있습니다. 2) Domapi를 통해 웹 페이지 조작, 3) 애니메이션 및 드래그 앤 드롭과 같은 복잡한 대화식 효과를 지원합니다. 4) 성능 및 모범 사례를 최적화하여 사용자 경험을 향상시킵니다.

C 및 JavaScript는 WebAssembly를 통한 상호 운용성을 달성합니다. 1) C 코드는 WebAssembly 모듈로 컴파일되어 컴퓨팅 전력을 향상시키기 위해 JavaScript 환경에 도입됩니다. 2) 게임 개발에서 C는 물리 엔진 및 그래픽 렌더링을 처리하며 JavaScript는 게임 로직 및 사용자 인터페이스를 담당합니다.

JavaScript는 웹 사이트, 모바일 응용 프로그램, 데스크탑 응용 프로그램 및 서버 측 프로그래밍에서 널리 사용됩니다. 1) 웹 사이트 개발에서 JavaScript는 HTML 및 CSS와 함께 DOM을 운영하여 동적 효과를 달성하고 jQuery 및 React와 같은 프레임 워크를 지원합니다. 2) 반응 및 이온 성을 통해 JavaScript는 크로스 플랫폼 모바일 애플리케이션을 개발하는 데 사용됩니다. 3) 전자 프레임 워크를 사용하면 JavaScript가 데스크탑 애플리케이션을 구축 할 수 있습니다. 4) node.js는 JavaScript가 서버 측에서 실행되도록하고 동시 요청이 높은 높은 요청을 지원합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

WebStorm Mac 버전
유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구
