我想在我的JavaScript代码中包含几个JSON文件,这些文件与我的JavaScript源文件位于同一目录中。
如果我想包含另一个JavaScript文件,我可以简单地使用require。 现在我使用readFileSync和__dirname来获取JSON,我认为这是一种丑陋的方式。
是否有类似的require使我能够加载JSON文件?
我想在我的JavaScript代码中包含几个JSON文件,这些文件与我的JavaScript源文件位于同一目录中。
如果我想包含另一个JavaScript文件,我可以简单地使用require。 现在我使用readFileSync和__dirname来获取JSON,我认为这是一种丑陋的方式。
是否有类似的require使我能够加载JSON文件?
当前回答
其中最常见的两种
第一种方法:
let jsonData = require('./JsonFile.json')
let jsonData = require('./JsonFile') //如果我们省略.json也可以
OR
import jsonData from ('./JsonFile.json')
第二种方式:
1)同步
const fs = require('fs')
let jsonData = JSON.parse(fs.readFileSync('JsonFile.json', 'utf-8'))
2)异步
const fs = require('fs')
let jsonData = {}
fs.readFile('JsonFile.json', 'utf-8', (err, data) => {
if (err) throw err
jsonData = JSON.parse(data)
})
注意: 1)如果我们JsonFile。如果json被改变了,我们不会得到新的数据,即使我们重新运行require('./JsonFile.json')
2) fs。readFile或fs。readFileSync将总是重新读取文件,并获得更改
其他回答
不。使用readFile或readFileSync(仅在启动时使用后者)。
或者使用现有的库
中信
或者把你的配置写在js文件中,而不是json文件
module.exports = {
// json
}
从节点v0.5开始。是的,你可以需要你的JSON,就像你需要一个js文件。
var someObject = require('./somefile.json')
在ES6:
import someObject from './somefile.json'
如果你正在使用typescript,你可以添加你的tsconfig。为json添加一个名为resolveJsonModule: true的新字段,然后你可以像这样导入任何.json文件的所有信息:
Import * as jsonfile from "./path/to/json"
其中最常见的两种
第一种方法:
let jsonData = require('./JsonFile.json')
let jsonData = require('./JsonFile') //如果我们省略.json也可以
OR
import jsonData from ('./JsonFile.json')
第二种方式:
1)同步
const fs = require('fs')
let jsonData = JSON.parse(fs.readFileSync('JsonFile.json', 'utf-8'))
2)异步
const fs = require('fs')
let jsonData = {}
fs.readFile('JsonFile.json', 'utf-8', (err, data) => {
if (err) throw err
jsonData = JSON.parse(data)
})
注意: 1)如果我们JsonFile。如果json被改变了,我们不会得到新的数据,即使我们重新运行require('./JsonFile.json')
2) fs。readFile或fs。readFileSync将总是重新读取文件,并获得更改
一个漂亮的非缓存异步一行,用于节点15模块:
import { readFile } from 'fs/promises';
const data = await readFile('{{ path }}').then(json => JSON.parse(json)).catch(() => null);