How to read an external local JSON file in JavaScript?

前端 未结 22 1973
醉酒成梦
醉酒成梦 2020-11-22 02:53

I have saved a JSON file in my local system and created a JavaScript file in order to read the JSON file and print data out. Here is the JSON file:

{"res         


        
相关标签:
22条回答
  • 2020-11-22 03:01

    For reading the external Local JSON file (data.json) using javascript, first create your data.json file:

    data = '[{"name" : "Ashwin", "age" : "20"},{"name" : "Abhinandan", "age" : "20"}]';
    
    1. Mention the path of the json file in the script source along with the javascript file.

      <script type="text/javascript" src="data.json"></script>
      <script type="text/javascript" src="javascrip.js"></script>
      
    2. Get the Object from the json file

      var mydata = JSON.parse(data);
      alert(mydata[0].name);
      alert(mydata[0].age);
      alert(mydata[1].name);
      alert(mydata[1].age);
      

    For more information, see this reference.

    0 讨论(0)
  • 2020-11-22 03:02

    One simple workaround is to put your JSON file inside a locally running server. for that from the terminal go to your project folder and start the local server on some port number e.g 8181

    python -m SimpleHTTPServer 8181
    

    Then browsing to http://localhost:8181/ should display all of your files including the JSON. Remember to install python if you don't already have.

    0 讨论(0)
  • 2020-11-22 03:04
    1. First, create a json file. In this example my file is words.json

    [{"name":"ay","id":"533"},
    {"name":"kiy","id":"33"},
    {"name":"iy","id":"33"},
    {"name":"iy","id":"3"},
    {"name":"kiy","id":"35"},
    {"name":"kiy","id":"34"}]

    1. And here is my code i.e,node.js. Note the 'utf8' argument to readFileSync: this makes it return not a Buffer (although JSON.parse can handle it), but a string. I am creating a server to see the result...

    var fs=require('fs');
    var data=fs.readFileSync('words.json', 'utf8');
    var words=JSON.parse(data);
    var bodyparser=require('body-parser');
    console.log(words);
    var express=require('express');
    
    var app=express();
    
    var server=app.listen(3030,listening);
    
    function listening(){
    console.log("listening..");
    }
    app.use(express.static('website'));
    app.use(bodyparser.urlencoded({extended:false}));
    app.use(bodyparser.json());

    1. When you want to read particular id details you can mention the code as..

     app.get('/get/:id',function(req,res){
    	
    var i;
    		 
     for(i=0;i<words.length;++i)
     {
     if(words[i].id==req.params.id){
     res.send(words[i]);
     }
    }
    console.log("success");
    	  
    });

    1. When you entered in url as localhost:3030/get/33 it will give the details related to that id....and you read by name also. My json file has simillar names with this code you can get one name details....and it didn't print all the simillar names

     app.get('/get/:name',function(req,res){
    	
    var i;
    		 
     for(i=0;i<words.length;++i)
     {
     if(words[i].id==req.params.name){
     res.send(words[i]);
     }
    }
    console.log("success");
    	  
    });

    1. And if you want to read simillar name details, you can use this code.

    app.get('/get/name/:name',function(req,res){
    word = words.filter(function(val){
      return val.name === req.params.name;
    });
    res.send(word);
    			 
     console.log("success");
    	  
    });

    1. If you want to read all the information in the file then use this code below.

    app.get('/all',sendAll);
     
     function sendAll(request,response){
     response.send(words);
    
     }
     

    0 讨论(0)
  • 2020-11-22 03:04

    Since you have a web application, you may have a client and a server.

    If you have only your browser, and you want to read a local file from a javascript that is running in your browser, that means that you have only a client. For security reasons, the browser should not let you do such thing.

    However, as lauhub explained above, this seems to work:

    http://www.html5rocks.com/en/tutorials/file/dndfiles/

    Other solution is to setup somewhere in your machine a web server (tiny in windows or monkey in linux) and with an XMLHttpRequest or D3 library, request the file from the server and read it. The server will fetch the file from the local filesystem, and serve it to you through the web.

    0 讨论(0)
  • 2020-11-22 03:05

    The loading of a .json file from harddisk is an asynchronous operation and thus it needs to specify a callback function to execute after the file is loaded.

    function readTextFile(file, callback) {
        var rawFile = new XMLHttpRequest();
        rawFile.overrideMimeType("application/json");
        rawFile.open("GET", file, true);
        rawFile.onreadystatechange = function() {
            if (rawFile.readyState === 4 && rawFile.status == "200") {
                callback(rawFile.responseText);
            }
        }
        rawFile.send(null);
    }
    
    //usage:
    readTextFile("/Users/Documents/workspace/test.json", function(text){
        var data = JSON.parse(text);
        console.log(data);
    });
    

    This function works also for loading a .html or .txt files, by overriding the mime type parameter to "text/html", "text/plain" etc.

    0 讨论(0)
  • 2020-11-22 03:11

    You must create a new XMLHttpRequest instance and load the contents of the json file.

    This tip work for me (https://codepen.io/KryptoniteDove/post/load-json-file-locally-using-pure-javascript):

     function loadJSON(callback) {   
    
        var xobj = new XMLHttpRequest();
            xobj.overrideMimeType("application/json");
        xobj.open('GET', 'my_data.json', true); // Replace 'my_data' with the path to your file
        xobj.onreadystatechange = function () {
              if (xobj.readyState == 4 && xobj.status == "200") {
                // Required use of an anonymous callback as .open will NOT return a value but simply returns undefined in asynchronous mode
                callback(xobj.responseText);
              }
        };
        xobj.send(null);  
     }
    
     loadJSON(function(response) {
        // Parse JSON string into object
        var actual_JSON = JSON.parse(response);
     });
    
    0 讨论(0)
提交回复
热议问题