0

我能够使用 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);
4

1 回答 1

0

您的 html 字符串中有引号:

"html":"<fieldset id="formelement_1" class="radio">

这完全被破坏了(字符串值以 结尾id=")。

您需要使用 . 转义引号\"

编辑:当然这是“为什么它不起作用”的答案。更好的方法确实是使用 JSON.stringify 序列化您的对象,正如 Kevin 的评论中所建议的那样,它可以解决这个问题和其他问题。

于 2013-09-03T18:35:41.923 回答