json
=
{
contry:{
area:{
man:"12万",
women:"10万"
}
}
}
//方式一:使用eval解析
var
obj
=
eval(json)
alert(obj.constructor)
alert(obj.contry.area.women)
//方式二:使用Funtion函数
var
strJSON
=
"{name:'json
name'}"//得到的JSON
var
obj
=
new
Function("return"
+
strJSON)()//转换后的JSON对象
alert(obj.name)//json
name
alert(obj.constructor)
//复杂一点的json数组数据的解析
var
value1
=
[{"c01":"1","c02":"2","c03":"3","c04":"4","c05":"5","c06":"6","c07":"7","c08":"8","c09":"9"},
{"c01":"2","c02":"4","c03":"5","c04":"2","c05":"8","c06":"11","c07":"21","c08":"1","c09":"12"},
{"c01":"5","c02":"1","c03":"4","c04":"11","c05":"9","c06":"8","c07":"1","c08":"8","c09":"2"}]
var
obj1
=
eval(value1)
alert(obj1[0].c01)
//复杂一点的json的另一种形式
var
value2
=
{"list":[
{"password":"1230","username":"coolcooldool"},
{"password":"thisis2","username":"okokok"}],
"array":[{"password":"1230","username":"coolcooldool"},{"password":"thisis2","username":"okokok"}]}
var
obj2
=
eval(value2)
alert(obj2.list[0].password)
如果要使用js读取json文件,那么ajax操作是必须的了。原生ajax有点麻烦,我想你们项目一定用了什么js库,这里给个jquery的例子:<br>$.get('xx.json路径', function(data){<br> alert(data)// data即为json文件内容里的json数据<br>}, 'json')如果把这个文件的内容读取为纯文本,可以修改$.get的最后一个参数json为text,或者删掉这个参数,默认也是text。问题1:js访问本地json
如果可以这样随意访问,你打开的任何网站不就可以通过js把你本地文件全部获取到了吗,这是非常危险的;这个不是技术上的能不能,而是安全策略问题,解决方法肯定有,大概是给浏览器某种授权。
我比较推荐换一种方式来解决这个问题,你要的结果是访问json文件,如果json文件不是很大的话,何不直接用个js变量保存它的值;
另外可以考虑部署到服务器,通过ajax请求获取,通过jquery可以如下写:
$.get('/content/test.json', function(data) {alert(data)})
问题2:如何在前端显示
js操纵DOM,可以简单粗暴地加到body里,当然有更好展现方式,推荐单独写个div:
$('body').append(data)