data={class=S1,name=11,age=11,math=12,eng=33,chinese=100;class=S1,name=12,age=12,math=120,eng=33,chinese=10;class=S1,name=13,age=13,math=130,eng=330,chinese=10;class=S2,name=21,age=21,math=22,eng=222,chinese=55,phy=300;class=S2,name=22,age=22,math=212,eng=220,chinese=55,phy=30;class=S2,name=23,age=23,math=21,eng=22,chinese=55,phy=3;class=S3,name=33,age=33,math=31,eng=32,chinese=355,phy=333,bio=400;}里面有三个类,每个类的属性个数也不一样,怎么解析然后生成对象。
var str="data={class=S1,name=11,age=11,math=12,eng=33,chinese=100;class=S1,name=12,age=12,math=120,eng=33,chinese=10;class=S1,name=13,age=13,math=130,eng=330,chinese=10;class=S2,name=21,age=21,math=22,eng=222,chinese=55,phy=300;class=S2,name=22,age=22,math=212,eng=220,chinese=55,phy=30;class=S2,name=23,age=23,math=21,eng=22,chinese=55,phy=3;class=S3,name=33,age=33,math=31,eng=32,chinese=355,phy=333,bio=400;}"
str=str.split("{")[1].split("}")[0];
var arr= [];
str.split(";").forEach(function(v){
var obj = {};
v.split(",").forEach(function(name){
var prop = name.split("=")[0];
var data = name.split("=")[1];
obj[prop]=data;
})
arr.push(obj);
})
//最后一个是空的。
arr.pop();
console.log(arr);