js字符串转换为json格式的问题
麻烦看下这样一个问题,代码如下:<selectid="select1"></select><script>vara=[{text:'广东',value:"1"},{tex...
麻烦看下这样一个问题,代码如下:
<select id="select1"></select>
<script>
var a=[{text:'广东',value:"1"},{text:'海南',value:"2"},{text:'山西',value:"3"}];
此处的a,我如果直接这样赋值,下面代码可以正确执行,将对应的值插入到dropdownlist中,但当我用ajax从后台以上面那种格式获取值(字符串类型)赋值给a以后,发现下面的代码不能正常执行了,我调试了一下,发现是因为ajax返回的是字符串型,而此处的好像是json格式吧(具体我也不是很清楚),请问可以怎么解决,谢谢!
var $ = function (id) {
return document.getElementById(id);
};
var bind = function(o) {
for (var i = 0 , l = a.length; i < l ;i++) {
var oOption = document.createElement("option");
oOption.text = a[i].text;
oOption.value = a[i].value;
o.add(oOption);
}
}
window.onload = function () {
bind($('select1'));
}
</script>
已经解决了,但会报一个内部错误(internal.error) 展开
<select id="select1"></select>
<script>
var a=[{text:'广东',value:"1"},{text:'海南',value:"2"},{text:'山西',value:"3"}];
此处的a,我如果直接这样赋值,下面代码可以正确执行,将对应的值插入到dropdownlist中,但当我用ajax从后台以上面那种格式获取值(字符串类型)赋值给a以后,发现下面的代码不能正常执行了,我调试了一下,发现是因为ajax返回的是字符串型,而此处的好像是json格式吧(具体我也不是很清楚),请问可以怎么解决,谢谢!
var $ = function (id) {
return document.getElementById(id);
};
var bind = function(o) {
for (var i = 0 , l = a.length; i < l ;i++) {
var oOption = document.createElement("option");
oOption.text = a[i].text;
oOption.value = a[i].value;
o.add(oOption);
}
}
window.onload = function () {
bind($('select1'));
}
</script>
已经解决了,但会报一个内部错误(internal.error) 展开
展开全部
错误原因:
前面你能成功取值是因为a是一个javascript对象而不是纯粹的字符串,所以可以用obj.attr的方式读取数值,
后面你用ajax获取的相似格式字符串的实际为JSON格式的字符串,所以用对象方法读值失败。
解决思路:
将JSON文本转换为JavaScript 对象后再用obj.attr的方式读值。
JSON 文本格式在语法上与创建 JavaScript 对象的代码相同。
由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 JavaScript 对象。
具体方法:
假设用ajax获取的json文本存于变量jsonText中
var a = eval("(" + jsonText + ")");
相关资料:
http://www.w3school.com.cn/json/json_eval.asp
追问
不行,我试过了
追答
查看ajax返回的json文本,看格式究竟是这个:
[{text:'广东',value:"1"},{text:'海南',value:"2"},{text:'山西',value:"3"}]
还是这个:
{ "data":[{text:'广东',value:"1"},{text:'海南',value:"2"},{text:'山西',value:"3"}] }
如果是后者,应该这么取值
var a = eval("(" + jsonText + ")");
a.data[i].text
a.data[i].value
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询