我能够使用 jQuery 的“$.parseJSON();”成功解析使用 JSON 手动初始化的变量 但我无法解析使用数组构造的具有相同 JSON 格式的变量。
Javascript
var questionstype = [];
var questionshtml = [];
var questionsquestion = [];
//Store all questions, types, and html for each fieldset into 3 separate arrays
for(var i=1;i<=formpreviewid;i++)
{
questionsquestion.push($("#formelement_"+i + " legend").text());
questionstype.push($("#formelement_"+i).attr("class"));
questionshtml.push($("#formelement_"+i)[0].outerHTML);
};
//alert(questionsquestion[1] + questionstype[1] + questionshtml[1]);
//format values for each fieldset into values format in mysql
var questionsvalues = [];
var index = 0;
for(var i=1;i<=formpreviewid;i++)
{
questionsvalues.push('{"question":"'+questionsquestion[index]+'","type":"'+questionstype[index]+'","html":"'+questionshtml[index]+'"}');
index++;
};
//alert(questionsvalues);
//questionsvalues = questionsvalues.replace("}{", "},{");
//alert(questionsvalues);
//format mysql values into JSON format
var questionsvaluesjson = '{"questions":['+questionsvalues+']}';
使用具有相同 JSON 格式的手动构造的字符串变量 --
var questionsquestion2 = '{"questions":[{"question":"test16","type":"radio", "html":"<input>"},{"question":"test2","type":"checkbox", "html":"<input>"},{"question":"test3","type":"checkbox", "html":"<input>"}]}';
ParseJSON(questionsvaluesjson); //works fine
使用从数组构造的字符串——
var questionsvaluesjson = '{"questions":['+questionsvalues+']}';
Alert(questionsvaluesjson) :
{"questions":[{"question":"d","type":"radio","html":"<fieldset id="formelement_1" class="radio"><tr><td colspan="2"><legend>d</legend></td></tr><tr><td><label for="1_1">d</label></td><td><input name="radio1" value="d" type="radio"></td></tr><tr><td><label for="1_2">d</label></td><td><input name="radio1" value="d" type="radio"></td></tr></fieldset>"}]}
ParseJSON(questionsvaluesjson); //Breaks script
我将此 JSON 发送到要解码的 php 文件,然后在 foreach 循环中使用,我可以在其中操作对象以将数据插入 mysql 数据库,但目前它在尝试在 foreach 循环中使用对象时抛出错误。
这是错误:'试图获取非对象的属性'
这是代码:
PHP
foreach ($theArray->questions as $data)
{
$insert .= '("' . $data->question . '", "' . $data->type . '", "' . $data->html . '")';
}
$insert = str_replace(")(","),(",$insert);
$query = "INSERT INTO registrationquestions (question, type, html) VALUES " . $insert;
$mysqli->query($query);