Сенча Touch Script Tag Прокси JSON Reader Ошибка разбора - PullRequest
0 голосов
/ 05 октября 2011

Я пытаюсь использовать прокси тега сценария Sencha Touch, чтобы использовать файл JSON на удаленном веб-сайте, однако я вижу ошибки синтаксического анализа в консоли Safari, даже если я подтвердил, что файл JSON правильный.

Моя модель такая:

    Ext.regModel('NoteNewsModel', {
    idProperty: 'id',
    fields: [
        { name: 'id', type: 'int' },
        { name: 'title', type: 'string' },
        { name: 'description', type: 'string' }
        // { name: 'icon', type: 'string' }
    ]
});    

Код моего магазина:

Ext.regStore('NotesNewsStore', {
    model: 'NoteNewsModel',
    proxy: {
        type: 'scripttag',
        url: 'myjsonurl',
        reader: new Ext.data.JsonReader ({
            type: 'json',
            root: 'entries'
        })
    },
    autoLoad: true
 });

Вот часть файла JSON на удаленном сервере:

{
 "title":"json news",
 "link":"https://myurl.com/json-news.html",
 "description":"",
 "language":"en",
 "copyright":"my domain",
 "ttl":"120",
 "entries":[
    {
     "title":"SmarterMail Upgrade",
     "link":"https://mydomain.com/122.html",
     "date":"1316414335",
     "guid":"https://mydomain.com/122.html",
     "author":"flank plank",
     "description":"test entry",
     "introtext":"testing the intro text."
    }
  ]
}

Наконец, ошибка, которую я вижу в консоли Safari, показана ниже первой строки

"title": json news ", data.json: 2SyntaxError: Ошибка разбора

Буду признателен за любую помощь в этом вопросе. Я уже несколько часов чесал голову об этом.

Спасибо, Аарон

Ответы [ 2 ]

0 голосов
/ 07 октября 2011

После долгих проб и ошибок я обнаружил, что это не работает из-за неправильного форматирования моего файла JSON.

Я последовал этому примеру: http://www.sencha.com/learn/legacy/Tutorial:Creating_JSON_Data_in_PHP

И с этим кодом на моем локальном сервере он теперь работает нормально.

<?php 

$link = mysql_pconnect("server", "user", "password") or die("Could not connect");
mysql_select_db("database") or die("Could not select database");

$arr = array();
$rs = mysql_query("SELECT * FROM news");

while($obj = mysql_fetch_object($rs)) {
    $arr[] = $obj;
}

$callback = $_REQUEST['callback'];
if ($callback) {
    header('Content-Type: text/javascript');
    echo $callback . '(' . json_encode($arr) . ');';
} else {
    header('Content-Type: application/x-json');
    echo json_encode($arr);
}

?>
0 голосов
/ 05 октября 2011

Попробуйте изменить это на следующее:

reader: {
            type: 'json',
            root: 'entries'
        }

Кроме того, в json нет идентификатора.

...