正常情况下从json文件读取到字符后再通过json.parse没什么问题,只要格式不出错
有时在确保json格式正确时仍然会出现unexpected token异常
经过调查发现里面有不会显示的unicode字符
于是确定是utf-8的问题,utf-8分有dom版和无dom版,一般编辑器不刻意设置会默认保存为带dom的utf8
解决办法是先将读到的文件转成二进制,然后检索dom符号删除
代码实现部分
function readtext(pathname) { var bin = fs.readfilesync(pathname); if (bin[0] === 0xef && bin[1] === 0xbb && bin[2] === 0xbf) { bin = bin.slice(3); } return bin.tostring('utf-8'); }
更多nodejs读取json文件格式化时的注意事项。
