【发布时间】:2011-01-16 11:01:45
【问题描述】:
我正在使用 JS 对象来创建具有 Google 可视化效果的图形。我正在尝试设计数据源。起初,我在客户端创建了一个 JS 对象。
var JSONObject = {
cols: [{
id: 'date',
label: 'Date',
type: 'date'
},
{
id: 'soldpencils',
label: 'Sold Pencils',
type: 'number'
},
{
id: 'soldpens',
label: 'Sold Pens',
type: 'number'
}
],
rows: [{
c: [{
v: new Date(2008, 1, 1),
f: '2/1/2008'
}, {
v: 30000
}, {
v: 40645
}]
},
{
c: [{
v: new Date(2008, 1, 2),
f: '2/2/2008'
}, {
v: 14045
}, {
v: 20374
}]
},
{
c: [{
v: new Date(2008, 1, 3),
f: '2/3/2008'
}, {
v: 55022
}, {
v: 50766
}]
}
]
};
var data = new google.visualization.DataTable(JSONObject, 0.5);
现在我需要动态获取数据。所以我向返回 JSON 字符串的页面发送 AJAX 请求:
"cols: [{id: 'date', label: 'Date', type: 'date'},
{id: 'soldpencils', label: 'Sold Pencils', type: 'number'},
{id: 'soldpens', label: 'Sold Pens', type: 'number'}],
rows: [{c:[{v: new Date(2008,1,1),f:'2/1/2008'},{v: 30000}, {v: 40645}]},
{c:[{v: new Date(2008,1,2),f:'2/2/2008'},{v: 14045}, {v: 20374}]},
{c:[{v: new Date(2008,1,3),f:'2/3/2008'},{v: 55022}, {v: 50766}]}"
我保存到一个变量中:
var var1 = "cols: [{i ....... 66}]}"
并显示为
alert(var1);
现在我的任务是从这个字符串创建一个 JS 对象。这是行不通的。当我使用 JS 对象时,一切正常,并且我能够获得所需的图表。现在,如果我尝试将来自 AJAX 请求的相同字符串值(我从警报消息中确认)放入 n 对象,则该对象未正确创建。请让我知道您的意见以及任何更正或建议。
【问题讨论】:
-
使用 javascript
eval(json_string)方法获取字符串到 json 对象。但请注意,同样的功能可能具有潜在危险,因为它也可以执行脚本。 -
仅供参考 - 键名和字符串必须在有效 JSON 中的
"内:simonwillison.net/2006/Oct/11/json
标签: javascript jquery json jsonp getjson