ext JS Grid文本区域json语法错误

时间:2014-02-11 15:43:47

标签: javascript php json extjs

我有项目在extjs网格面板中显示文本区域。表单成功完全成为文本区域并保存到数据库。但是当我从数据库加载它时,它显示语法错误

谷歌控制台中的

显示如下错误

Ext.data.JsonP.callback8({"totalItems": 2,"items": [{ "no": "1","kegiatan": "Target 12345 - 5432
asd
asd
asd
", "target": "harus sesuai target" },{ "no": "2","kegiatan": "Target 12 revisi error lagi", "target": "78.00" }]});

这里是request_form.js

创建的表单
function test(v){
    return v === undefined || v === null ? '' : v.replace(/\n/g, '<br>');
}
.......
xtype: 'gridpanel',
            id: 'frm_request_form_gridpanel',
            title: 'Rencana Target dan Pencapaian Kerja',
            width: 750,
            height: 300,
            border: 1,
            margin: '10 5 10 10',
            store: Ext.data.StoreManager.lookup('DetailTargetStore'),
            columns: [
                {header:'No',  dataIndex: 'no', width: 40},
                            {header:'Jenis Kegiatan', dataIndex: 'kegiatan',  
                                width: 350,
                                //type: 'textarea',
                                //grow:true,
                                //renderer:columnWrap
                               // field: {type: 'textarea',maxLength: 1024,renderer:columnWrap,grow:true}
                                renderer:test,
                                editor:'textarea',
                                flex: 1 
....
 handler: function(){
                          var dataObj = [];
              var dataEmployee = EmployeReqStore.data.items;

                          var editedRecords = DetailTargetStore.getModifiedRecords();
              for (var i=0; i<editedRecords.length; i++) {
                                dataObj.push(
                                    {
                                        tag_id:'edited',
                                        emp_id:Ext.getCmp('nik').getValue(),
                                        periode: Ext.getCmp('frm_request_form-periode').getValue(),
                                        ccgroup : dataEmployee[0].data.ccgroup_id,
                                        costcenter : dataEmployee[0].data.costcenter_id,
                                        location : dataEmployee[0].data.location_id,
                                        targetno: editedRecords[i].data.no,
                                        targetket: editedRecords[i].data.kegiatan,
                                        targetnilai: editedRecords[i].data.target,
                                        //targettipe: editedRecords[i].data.target_tipe,
                                        status: 'DRAFT' 
                                    }
                                );
                            }  
.....
 id: 'SubmitBtn', 
                        text: 'Submit',
                        handler: function(){
                          var dataObj = [];
                          var dataEmployee = EmployeReqStore.data.items;

                          var editedRecords = DetailTargetStore.getModifiedRecords();
              for (var i=0; i<editedRecords.length; i++) {
                                dataObj.push(
                                    {
                                        tag_id:'edited',
                                        emp_id:Ext.getCmp('nik').getValue(),
                                        periode: Ext.getCmp('frm_request_form-periode').getValue(),
                                        ccgroup : dataEmployee[0].data.ccgroup_id,
                                        costcenter : dataEmployee[0].data.costcenter_id,
                                        location : dataEmployee[0].data.location_id,
                                        targetno: editedRecords[i].data.no,
                                        targetket: editedRecords[i].data.kegiatan,
                                        targetnilai: editedRecords[i].data.target,
                                        //targettipe: editedRecords[i].data.target_tipe,
                                        status: 'NEW' 
                                    }
                                );
                            }  

这里用json对象保存php

foreach ($dataObj as $object) {
...
 $stmtupdt = $db->prepare($sqlupdt);
                               $stmtupdt->execute(array(
                                      ':docno_id' => $doc_no,
                                      ':target_ket' => $object->targetket,
                                      //':target_tipe' => $object->targettipe,
                                      ':target_nilai' => $object->targetnilai,
                                      ':target_no' => $object->targetno, 
                                      ':target_status' => $object->status,
                                      ':periode_id' => $object->periode)
...

这里用json对象加载php

$result = mysql_query($sql);
$totalitem = mysql_num_rows($result);
$count = 0;
echo '"totalItems": ' . $totalitem. ',';    
echo '"items": [';
if ($result) {
    if ($totalitem>0){

        while($row = mysql_fetch_array($result)){
            if(++$count == $totalitem) {
                echo '{ "no": "'.$row['target_no'].'","kegiatan": "'. htmlentities($row['target_ket']).'", "target": "'.$row['target_nilai'].'" }';
            }
            else {
                echo '{ "no": "'.$row['target_no'].'","kegiatan": "'. htmlentities($row['target_ket']).'", "target": "'.$row['target_nilai'].'" },';                
            }            
        }    

我认为json传递对象有些问题,但我不知道如何修复json。请给我解决方案 谢谢

2 个答案:

答案 0 :(得分:0)

错误消息Uncaught SyntaxError: Unexpected token ILLEGAL通常表示未在同一行上关闭的字符串,换句话说是字符串中未转义的新行。

答案 1 :(得分:0)

构建PHP数组,并使用json_encode

$items = array();
while ($row = mysql_fetch_array($result)) {
    $items[] = array(
        'no' => $row['target_no'],
        'kegiatan' => htmlentities($row['target_ket']),
        'target' => $row['target_nilai'],
    );
}

echo json_encode(array(
    'totalItems' => $totalItems,
    'item' => $items,
));