


Overview of the impact of escape characters () on JSON.parse in JavaScript_Basics
According to the explanation in the fifth edition of ECMA262, JSON is a built-in object that provides stringify and parse methods. The former is used to convert js objects into strings that conform to json standards, and the latter converts strings that conform to json standards into js objects. . json standard reference json.org . (In fact, you can use eval to convert a string that conforms to the json standard into a js object, but eval has relatively poor performance and has security risks (it will execute the code in the json string). This article only writes JSON)
This article writes about conversion The impact of meaning characters on the JSON.parse method.
Generally speaking, when the parameters of JSON.parse contain transfer characters, you will encounter two escaping problems. In fact, the first time is the escaping of the string itself, and the second time is the actual conversion to Escape of js objects.
An example is as follows:
Example 1: Pass the string '{"a":"b","b":"\\"}' to JSON.parse, first the parser extracts the single quotes When enclosing a string, it is considered that the first one is escaped, the second one is escaped, and the third one is escaped the fourth one. That is to say, the actual output string is {"a":"b","b":"\"} (It can be verified through console.log('{"a":"b","b":"\\"}')), and then there is another escape when it is officially converted into a js object, which is the actual output character. The first one escapes the second one (there are only two at this point). So console.log(JSON.parse('{"a":"b","b":"\\"}') ); the output result is Object {a: "b", b: ""}, also That is to say, the actual displayed data is one (actually one data can be output, indicating that there is another one before this).
Example 2:
var obj = {
a : "b",
b : "\",
c : {
b : "\",
a : {
b : "\"
}
}
};
var json_str = JSON.stringify(obj);
console.log( JSON.stringify(obj) ) ;
console.dir(JSON.parse(json_str));
console.dir(JSON.parse('{"a":"b","b":"\\","c": {"b":"\\","a":{"b":"\\"}}}'));The output result is as shown below
pic
According to the escaping rules, the actual output is There must be one before this one. So the output of the first line above is '{"a":"b","b":"\\","c":{"b":"\\","a":{" b":"\\"}}}', which can be verified by the third output.
To summarize, if you want one to appear in the js object, four need to appear in the json string.
For other special characters
1. Double quotation mark ("), if the double quotation mark appears correctly, it should be \"
2.n, if you think about it, The correct line breaks required in the json string are
, in fact, we first escape the characters in n, and n becomes an ordinary character. When parsed into a js object, n and the previous one (only one left) are interpreted as newlines. The following two are similar to this.
3.r,
4.t,

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The combination of golangWebSocket and JSON: realizing data transmission and parsing In modern Web development, real-time data transmission is becoming more and more important. WebSocket is a protocol used to achieve two-way communication. Unlike the traditional HTTP request-response model, WebSocket allows the server to actively push data to the client. JSON (JavaScriptObjectNotation) is a lightweight format for data exchange that is concise and easy to read.

MySQL5.7 and MySQL8.0 are two different MySQL database versions. There are some main differences between them: Performance improvements: MySQL8.0 has some performance improvements compared to MySQL5.7. These include better query optimizers, more efficient query execution plan generation, better indexing algorithms and parallel queries, etc. These improvements can improve query performance and overall system performance. JSON support: MySQL 8.0 introduces native support for JSON data type, including storage, query and indexing of JSON data. This makes processing and manipulating JSON data in MySQL more convenient and efficient. Transaction features: MySQL8.0 introduces some new transaction features, such as atomic

Performance optimization methods for converting PHP arrays to JSON include: using JSON extensions and the json_encode() function; adding the JSON_UNESCAPED_UNICODE option to avoid character escaping; using buffers to improve loop encoding performance; caching JSON encoding results; and considering using a third-party JSON encoding library.

Quick Start: Pandas method of reading JSON files, specific code examples are required Introduction: In the field of data analysis and data science, Pandas is one of the important Python libraries. It provides rich functions and flexible data structures, and can easily process and analyze various data. In practical applications, we often encounter situations where we need to read JSON files. This article will introduce how to use Pandas to read JSON files, and attach specific code examples. 1. Installation of Pandas

Annotations in the Jackson library control JSON serialization and deserialization: Serialization: @JsonIgnore: Ignore the property @JsonProperty: Specify the name @JsonGetter: Use the get method @JsonSetter: Use the set method Deserialization: @JsonIgnoreProperties: Ignore the property @ JsonProperty: Specify name @JsonCreator: Use constructor @JsonDeserialize: Custom logic

Use the json.MarshalIndent function in golang to convert the structure into a formatted JSON string. When writing programs in Golang, we often need to convert the structure into a JSON string. In this process, the json.MarshalIndent function can help us. Implement formatted output. Below we will explain in detail how to use this function and provide specific code examples. First, let's create a structure containing some data. The following is an indication

How to handle XML and JSON data formats in C# development requires specific code examples. In modern software development, XML and JSON are two widely used data formats. XML (Extensible Markup Language) is a markup language used to store and transmit data, while JSON (JavaScript Object Notation) is a lightweight data exchange format. In C# development, we often need to process and operate XML and JSON data. This article will focus on how to use C# to process these two data formats, and attach

Using PHP's json_encode() function to convert an array or object into a JSON string and format the output can make it easier to transfer and exchange data between different platforms and languages. This article will introduce the basic usage of the json_encode() function and how to format and output a JSON string. 1. Basic usage of json_encode() function The basic syntax of json_encode() function is as follows: stringjson_encod
