search
HomeWeb Front-endJS TutorialJSON learning complete manual with pictures and text_javascript skills

Chapter 1 What is JOSN
JSON: JavaScript Object Notation

is Javascript (jscript, ECMA Javascript, etc.) describing object data (various metadata are actually the simplest objects) A data structure. The concept and usage are similar to Hash (hash table) or associative array.

JSON is constructed from two structures:

A collection of name/value pairs. In different languages, it is understood as an object, a record, a struct, a dictionary, a hash table, a keyed list, or an associative array. array).
An ordered list of values. In most languages, it is understood as an array.
These are common data structures. In fact most modern computer languages ​​support them in some form. This makes it possible for a data format to be exchanged between programming languages ​​that are also based on these structures.

The simplest JSON example is as follows:

Copy code The code is as follows :

[
{ name:"Michael", email:"17bity@gmail.com", homepage:"http://www.jb51.net" },
{ name:"John", email:"john@gmail.com", homepage:"http://s.jb51.net" },
{ name:"Peggy", email:"peggy@gmail.com" , homepage:"http://tools.jb51.net" }]


The following example describes an email contact list. Running with eval in javascript will get a maillist object. Entity, then you can use javascript for further operations.

Copy code The code is as follows:

var maillist = [
{ name :"Michael", email:"17bity@gmail.com", homepage:"http://www.jb51.net" },
{ name:"John", email:"john@gmail.com", homepage:"http://s.jb51.net" },
{ name:"Peggy", email:"peggy@gmail.com", homepage:"http://tools.jb51.net" }
]

Then you can use javascript for further operations.

Chapter 2 JSON Format

The basic format of JSON is as follows, the picture comes from json.org:
An object is a collection of attribute and value pairs. An object starts with "{" and ends with "}". Use ":" to prompt between each attribute name and value, and use "," to separate attributes.

点击在新窗口中浏览此图片

An array is an ordered collection of values. An array starts with "[" and ends with "]", and the values ​​are separated by ",".

点击在新窗口中浏览此图片

The definition of string is basically the same as C or Java.
点击在新窗口中浏览此图片

The definition of numbers is basically the same as C or Java.
点击在新窗口中浏览此图片


Chapter 3 Using trimpath Template to make JSON templates

Trimpath Template is used to parse Json data and generate web page code lightweight JS code.

Demo: http://demo.jb51.net/js/js_template/test.htm

trimpath.template is based on JavaScript, cross-browser, using APL /GPL open source code agreement, which allows you to easily create a pure JS engine based on template programming.

http://code.google.com/p/trimpath/

It has the following characteristics:

1. Using standard JavaScript Writing, supporting cross-browser
2. Template syntax is similar to: FreeMarker, Velocity, Smarty
3. Use simple language to describe large strings and Dom/DHTML operations
4. It can be very convenient Parses data in XML file format into the specified template.

Using this engine, you can let it completely handle View matters, and the server-side Module can directly output Data. Let your MVC model be integrated, and since the View is processed by the browser, the burden on the server is greatly reduced. It is a very good choice to build network information system applications with Ajax technology.

This is a simple and compact template tool class, used to help users quickly assemble the required strings.

Simple explanation: in the template, between #{ ... /} The data will be executed as a js script, and the VAR keyword represents the value of seed (a changed value passed in from the outside).
The template is divided into two parts for execution, compile and run. #{.. The part between ../} is executed during run, and the part between
#{#...../} is executed during compilation. Seed cannot be passed into the code executed during compilation.
There is no need to write more explanations, because it is indeed a very simple function.

Principle: In fact, it uses the passed parameters to replace the #{ .../} part in the template string .(Execute eval() on the part between #{ .../}, and then replace it).


If you are interested in template technology, you can also learn more by studying the code inspiration.

Summary

As the default data format of JAVASCRIPT, json is very convenient for Ajax operations and is much smaller than XML files. Therefore, it has better performance in situations where the network speed is not ideal and the system coupling degree is relatively high.

But XML, as a self-describing format, has wider applications around the world. Therefore, when the system requires cross-platform and cross-language, XML is still the best choice.​
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
VUE3怎么使用JSON编辑器VUE3怎么使用JSON编辑器May 12, 2023 pm 05:34 PM

1、先看看效果图,可以自行选择展示效果2、这是我在vue3项目中使用的JSON编辑器,首先引入第三方插件npminstalljson-editor-vue3yarnaddjson-editor-vue33、引入到项目中//导入模块importJsonEditorVuefrom'json-editor-vue3'//注册组件components:{JsonEditorVue},4、一般后端返回的是会将JSON转为String形式我们传给后端也是通过这种形式,就可以通

SpringBoot之Json的序列化和反序列化问题怎么解决SpringBoot之Json的序列化和反序列化问题怎么解决May 12, 2023 pm 04:07 PM

控制json序列化/反序列化1.@JsonIgnoreProperties的用法@JsonIgnoreProperties(value={"prop1","prop2"})用来修饰Pojo类,在序列化和反序列化的时候忽略指定的属性,可以忽略一个或多个属性.@JsonIgnoreProperties(ignoreUnknown=true)用来修饰Pojo类,在反序列化的时候忽略那些无法被设置的属性,包括无法在构造子设置和没有对应的setter方法.2.@Js

Java怎么调用接口获取json数据解析后保存到数据库Java怎么调用接口获取json数据解析后保存到数据库May 14, 2023 am 10:58 AM

Java调用接口获取json数据保存到数据库1.在yml文件中配置自己定义的接口URL//自己定义的JSON接口URLblacklist_data_url:接口URL2.在Controller中添加请求方法和路径/***@Title:查询*@Description:查询车辆的记录*@Author:半度纳*@Date:2022/9/2717:33*/@GetMapping("/Blacklist")publicvoidselectBlacklist(){booleana=imB

深入解析JWT(JSON Web Token)的原理及用法深入解析JWT(JSON Web Token)的原理及用法Jan 10, 2023 am 10:55 AM

本篇文章给大家带来了关于JWT的相关知识,其中主要介绍了什么是JWT?JWT的原理以及用法是什么?感兴趣的朋友,下面一起来看一下吧,希望对大家有帮助。

php输出json无法解析的原因和解决方法【总结】php输出json无法解析的原因和解决方法【总结】Mar 23, 2023 pm 04:35 PM

PHP作为一种常见的编程语言,在web开发中使用广泛,其与前端交互的方式也多种多样。其中,输出Json数据是一种常见的交互方式,但有时候会碰到Json无法解析的问题。为什么会出现无法解析的情况呢?下面列举了几个可能的原因。

java怎么校验json的格式是否符合要求java怎么校验json的格式是否符合要求May 15, 2023 pm 04:01 PM

JSONSchemaJSONSchema是用于验证JSON数据结构的强大工具,Schema可以理解为模式或者规则。JsonSchema定义了一套词汇和规则,这套词汇和规则用来定义Json元数据,且元数据也是通过Json数据形式表达的。Json元数据定义了Json数据需要满足的规范,规范包括成员、结构、类型、约束等。JSONSchema就是json的格式描述、定义、模板,有了他就可以生成任何符合要求的json数据json-schema-validator在java中,对json数据格式的校验,使用

php如何将xml转为json格式?3种方法分享php如何将xml转为json格式?3种方法分享Mar 22, 2023 am 10:38 AM

当我们处理数据时经常会遇到将XML格式转换为JSON格式的需求。PHP有许多内置函数可以帮助我们执行这个操作。在本文中,我们将讨论将XML格式转换为JSON格式的不同方法。

SpringBoot怎么返回Json数据格式SpringBoot怎么返回Json数据格式May 19, 2023 pm 11:49 PM

一、@RestController注解在SpringBoot中的Controller中使用@RestController注解即可返回JSON格式的数据。@RestController注解包含了@Controller和@ResponseBody注解。@ResponseBody注解是将返回的数据结构转换为JSON格式。@Target({ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documented@Controller@Respons

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.