search
HomeWeb Front-endFront-end Q&AHow to use Node.js to add, delete, modify and query JSON data

Node.js is a fast, extensible JavaScript runtime whose functionality can be extended through the use of various modules. One of them is JSON (JavaScript Object Notation), a lightweight format for storing and exchanging data. In this article, I will show you how to use Node.js to add, delete, modify and query JSON data.

  1. Add JSON data

Node.js provides the fs module for reading and writing files. Saving JSON data to a file can be easily done using the fs module.

First, we need to create a JSON object and save it to a file. In the following code snippet, we create a students.json file and write a JSON object to the file:

const fs = require('fs');

const students = {
  "Tom": {
    "age": 18,
    "gender": "male"
  },
  "Lily": {
    "age": 19,
    "gender": "female"
  }
};

fs.writeFile('students.json', JSON.stringify(students), (err) => {
  if (err) throw err;
  console.log('The JSON data has been saved!');
});

In the above code, the method to write the file is fs.writeFile(), It requires three parameters: file name, data and callback function. The callback function accepts an error object as a parameter and returns null if the write is successful.

  1. Reading JSON data

Reading JSON data is also very simple. We just need to read the data from the file using the fs.readFile() method and convert it into a JSON object using the JSON.parse() method.

const fs = require('fs');

fs.readFile('students.json', (err, data) => {
  if (err) throw err;
  const students = JSON.parse(data);
  console.log(students);
});

In the above code, we read the students.json file and convert it into a JSON object using the fs.readFile() method. The callback function accepts an error object and data as parameters. If there is an error, the err parameter will contain the error information, otherwise it will contain the contents of the file.

  1. Modify JSON data

To modify JSON data, we only need to use JavaScript’s object attribute access symbol (.) or square bracket access symbol ([]) to change Properties in the object.

const fs = require('fs');

fs.readFile('students.json', (err, data) => {
  if (err) throw err;
  const students = JSON.parse(data);
  
  // 修改Tom的年龄为20
  students.Tom.age = 20;
  
  fs.writeFile('students.json', JSON.stringify(students), (err) => {
    if (err) throw err;
    console.log('The JSON data has been updated!');
  });
});

In the above code, we read the students.json file and convert it into a JSON object. We then change Tom's age to 20 and write the changed data back to the file.

  1. Delete JSON data

To delete attributes from a JSON object, we can use the delete keyword.

const fs = require('fs');

fs.readFile('students.json', (err, data) => {
  if (err) throw err;
  const students = JSON.parse(data);
  
  // 删除Lily
  delete students.Lily;
  
  fs.writeFile('students.json', JSON.stringify(students), (err) => {
    if (err) throw err;
    console.log('The JSON data has been updated!');
  });
});

In the above code, we delete the Lily property in the students object and write the changed data back to the file.

Summary

This is how to use Node.js to add, delete, modify and query JSON data. Use the fs module to read and write files, use the JSON.parse() method to convert JSON strings to JSON objects, and use the JSON.stringify() method to convert JSON objects to JSON strings. Using these methods, you can easily process JSON data so that it integrates seamlessly with your application.

The above is the detailed content of How to use Node.js to add, delete, modify and query JSON data. For more information, please follow other related articles on the PHP Chinese website!

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
CSS: Understanding the Difference Between Class and ID SelectorsCSS: Understanding the Difference Between Class and ID SelectorsMay 09, 2025 pm 06:13 PM

Classselectorsarereusableformultipleelements,whileIDselectorsareuniqueandusedonceperpage.1)Classes,denotedbyaperiod(.),areidealforstylingmultipleelementslikebuttons.2)IDs,denotedbyahash(#),areperfectforuniqueelementslikeanavigationmenu.3)IDshavehighe

CSS Styling: Choosing Between Class and ID SelectorsCSS Styling: Choosing Between Class and ID SelectorsMay 09, 2025 pm 06:09 PM

In CSS style, the class selector or ID selector should be selected according to the project requirements: 1) The class selector is suitable for reuse and is suitable for the same style of multiple elements; 2) The ID selector is suitable for unique elements and has higher priority, but should be used with caution to avoid maintenance difficulties.

HTML5: LimitationsHTML5: LimitationsMay 09, 2025 pm 05:57 PM

HTML5hasseverallimitationsincludinglackofsupportforadvancedgraphics,basicformvalidation,cross-browsercompatibilityissues,performanceimpacts,andsecurityconcerns.1)Forcomplexgraphics,HTML5'scanvasisinsufficient,requiringlibrarieslikeWebGLorThree.js.2)I

CSS: Is one style more priority than another?CSS: Is one style more priority than another?May 09, 2025 pm 05:33 PM

Yes,onestylecanhavemoreprioritythananotherinCSSduetospecificityandthecascade.1)Specificityactsasascoringsystemwheremorespecificselectorshavehigherpriority.2)Thecascadedeterminesstyleapplicationorder,withlaterrulesoverridingearlieronesofequalspecifici

What are the significant goals of the HTML5 specification?What are the significant goals of the HTML5 specification?May 09, 2025 pm 05:25 PM

ThesignificantgoalsofHTML5aretoenhancemultimediasupport,ensurehumanreadability,maintainconsistencyacrossdevices,andensurebackwardcompatibility.1)HTML5improvesmultimediawithnativeelementslikeand.2)ItusessemanticelementsforbetterreadabilityandSEO.3)Its

What are the limitations of React?What are the limitations of React?May 02, 2025 am 12:26 AM

React'slimitationsinclude:1)asteeplearningcurveduetoitsvastecosystem,2)SEOchallengeswithclient-siderendering,3)potentialperformanceissuesinlargeapplications,4)complexstatemanagementasappsgrow,and5)theneedtokeepupwithitsrapidevolution.Thesefactorsshou

React's Learning Curve: Challenges for New DevelopersReact's Learning Curve: Challenges for New DevelopersMay 02, 2025 am 12:24 AM

Reactischallengingforbeginnersduetoitssteeplearningcurveandparadigmshifttocomponent-basedarchitecture.1)Startwithofficialdocumentationforasolidfoundation.2)UnderstandJSXandhowtoembedJavaScriptwithinit.3)Learntousefunctionalcomponentswithhooksforstate

Generating Stable and Unique Keys for Dynamic Lists in ReactGenerating Stable and Unique Keys for Dynamic Lists in ReactMay 02, 2025 am 12:22 AM

ThecorechallengeingeneratingstableanduniquekeysfordynamiclistsinReactisensuringconsistentidentifiersacrossre-rendersforefficientDOMupdates.1)Usenaturalkeyswhenpossible,astheyarereliableifuniqueandstable.2)Generatesynthetickeysbasedonmultipleattribute

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)