我正在从隐藏的html输入字段中检索对象数组。我得到的字符串是:
"{"id":"1234","name":"john smith","email":"[email protected]"},{"id":"4431","name":"marry doe","email":"[email protected]"}"
现在,我需要再次将其作为对象数组传递。如何将该字符串转换为对象数组?
var array_of_objects = eval("[" + my_string + "]");
这将字符串作为代码执行,这就是为什么我们需要添加[]使其成为对象的原因。这也是eval最快,最简单的方法,为数不多的合法使用方法之一。 :D
假设str
拥有有效的JSON语法,您可以简单地调用eval(str)
。
出于安全考虑,最好使用JSON parser,如下所示:
JSON.parse(str);
请注意,str
必须包装在[]
中才能成为有效的JSON数组。
var str=eval([{'id':'1','txt':'name1'},{'id':'2','txt':'name2'},{'id':'3','txt':'name3'}])
for(var i=0;i<str.length;i++)
{
alert(str[i].txt);
}
[有很多格式错误的字符串对象,API的GET,旧代码等。格式错误并不意味着它会丢弃代码中的错误,但是会导致JSON.parse()输入的错误。
// not " wrapped key syntax
var str = "{ a: 2 }";
console.log( JSON.parse( str ) );
// SyntaxError: JSON.parse: expected property name or '}' at line 1 column 3 of the JSON data
// 'key', or 'value' syntax
var str = " { 'a': 2 } ";
console.log( JSON.parse( str ) );
// SyntaxError: JSON.parse: expected property name or '}' at line 1 column 3 of the JSON data
//syntax OK
var str = '{ "a": 2 }';
console.log( JSON.parse( str ) );
// Object { a: 2 }
有解决方案:
// Convert any-formatted object string to well formatted object string:
var str = "{'a':'1',b:20}";
console.log( eval( "JSON.stringify( " + str + ", 0, 1 )" ) );
/*
"{
"a": "1",
"b": 20
}"
*/
// Convert any-formatted object string to object:
console.log( JSON.parse( eval( "JSON.stringify( " + str + ", 0, 1 )" ) ) );
// Object { a: "1", b: 20 }