js字符串转json的三种简单方法举例
1.eval方式解析
function strToJson(str){
var json = eval("(" + str + ")");
return json;
}
console.log(strToJson("{'int':1, 'string':'demo'}"));运行截图:

注: 记得别忘了str两旁的小括号。
永远不要使用 eval !!!
eval() 是一个危险的函数, 它使用与调用者相同的权限执行代码。如果你用 eval() 运行的字符串代码被恶意方(不怀好意的人)修改,您最终可能会在您的网页/扩展程序的权限下,在用户计算机上运行恶意代码。更重要的是,第三方代码可以看到某一个 eval() 被调用时的作用域,这也有可能导致一些不同方式的攻击。相似的 Function 就不容易被攻击
2.new Function形式
function strToJson(str){
var json = (new Function("return " + str))();
return json;
}
console.log(strToJson("{'int':1, 'string':'demo'}"));运行截图:

3.使用全局的JSON对象
function strToJson(str){
return JSON.parse(str);
}
console.log(strToJson('{"int":1, "string":"demo"}'));
运行截图:

注: 单引号,双引号的位置。 使用JSON.parse需严格遵守JSON规范,如属性都需用引号引起来。
总结
到此这篇关于js字符串转json的三种简单方法的文章就介绍到这了,更多相关js字符串转json内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JS中getElementsByClassName与classList兼容性问题解决方案分析
这篇文章主要介绍了JS中getElementsByClassName与classList兼容性问题解决方案,结合实例形式分析了getElementsByClassName与classList的使用方法、原理及兼容性问题的处理技巧,需要的朋友可以参考下2019-08-08
firefox下input type="file"的size是多大
firefox对type="file" 的input的width定义目前是不支持的,但是FF支持size属性,可以给size设置一个值,来控制上传框的大小2011-10-10


最新评论