2

我在这段代码上遇到了问题。json 不允许双引号结果。前任。如果我有结果(一个悲伤的“故事”)json 不会解析它。

$('.loader1').show();
$.ajax({
  url: "findBook.php?action=populatemyacademy&bookCatId="+parentCategoryId+"",
  cache: false,
  dataType: "json",
  success: function(data) {
    $('.loader1').hide();
    $.each(data.items, function(i,item){
        $("#myAcademy").append('<div class="nameWrapper"><input name="checkMeM" type="checkbox" value="'+item.bookId+'"/><span title="'+item.bookName+'" class="checkBoxSpan">'+item.bookName+'</span></div>');
    });
}});

这是我在我的 php 脚本上生成 json 的方式

 $sql = "SELECT academyBookId, title FROM academy_book WHERE academyBookCategoryId = $bookCatId AND academyId = $academyId";
    $qPopulateAcademy = mysql_query($sql, $dbConMain) or die(__LINE__.' '.$sql.' '.mysql_error());
    while($rPopulateAcademy = mysql_fetch_array($qPopulateAcademy)){
        $rows[] = array('bookId' => $rPopulateAcademy [0], 'bookName' => $rPopulateAcademy [1]);
    }
    $jsdecode = json_encode($rows);
    echo "{items:$jsdecode}";
4

1 回答 1

4

问题是服务器在您的 JSON 文档中将其呈现为 " 并且这不起作用,因为 json_encode 使用 "" 进行包装,因此您可以执行以下操作:

$jsdecode = json_encode($rows,JSON_HEX_APOS|JSON_HEX_QUOT)

这将用它们的十六进制代码替换撇号和引号。

于 2011-03-08T03:03:19.647 回答