似乎无法在Extjs中远程填充组合框

时间:2013-02-06 18:47:42

标签: combobox extjs4.1

我已经尝试了所有的东西来填充组合下拉框。 当输入时,说“Apple”,它似乎正在加载数据但是,下拉框中没有任何结果。 Firebug显示已加载的数据。那么,我哪里错了?感谢。

Ext.create('Ext.form.field.ComboBox', { 
    fieldLabel: 'Basket',
    emptyText : 'Type a fruit name',
        queryMode : 'remote',
        minChars  : 3, 
        fields    : ['id', 'name'], 
        store     : { 
                    proxy: {
                type: 'jsonp',
                callbackKey: 'method',
                url: 'http://www.comparetrainfares.co.uk/train_scripts/data.php',
                reader: {
                root: 'items'
            },
                }
             },
        needleKey     : 'query',
        labelKey      : 'id',
        label         : 'name',
        displayField  : 'name',
        width         : 260, 
        forceSelection: true,
        renderTo      : query1,
});



<?php
header('Access-Control-Allow-Origin: *');
//header('Content-Type: application/json; charset=utf8');
//header('Content-Type: application/x-json');


// http://www.comparetrainfares.co.uk/train_scripts/data.php

$output = array();

$output[] = array('id' => '1', 'name' => 'Apple');
$output[] = array('id' => '2', 'name' => 'Banana');
$output[] = array('id' => '3', 'name' => 'Orange');
$output[] = array('id' => '4', 'name' => 'Lemon');

$objects = array('items' => $output);

echo json_encode($objects);
?>  

2 个答案:

答案 0 :(得分:0)

您正在使用jsonp代理。这不是加载商店的默认ajax方式。 php脚本应该从发送到php脚本的'callback'参数接收函数名称,然后返回的数据应该是这样的格式:

callback({"items":[{"id":"1","name":"Apple"},{"id":"2","name":"Banana"},{"id":"3","name":"Orange"},{"id":"4","name":"Lemon"}]})

请记住用回调参数中发送的任何字符串的名称替换'callback'。

答案 1 :(得分:0)

当我在组合框中输入单词“Appl”时,这就是我从FireBug获得的内容。我知道回来的数据与我正在输入的数据不同但是,即使我输入了应该匹配的东西,我仍然没有得到任何东西。

在'Params'标签下,我看到:

_dc 1361011625341
callback    Ext.data.JsonP.callback1
limit   10
page    1
query   appl
start   0

“响应”标签显示:

{rows:[{"id":"1","genre_name":"Comedy"},{"id":"2","genre_name":"Drama"},{"id":"3","genre_name":"Action"},{"id":"4","genre_name":"Mystery"}]}

'JSON'标签显示:

按键排序

rows    
[Object { id=    
"1"    
,  genre_name=    
"Comedy"    
}, Object { id=    
"2"    
,  genre_name=    
"Drama"    
}, Object { id=    
"3"    
,  genre_name=    
"Action"    
}, Object { id=    
"4"    
,  genre_name=    
"Mystery"    
}]    

0
    Object { id=    
"1"    
, genre_name=    
"Comedy"    
}       
1
    Object { id=    
"2"    
, genre_name=    
"Drama"    
}       
2
    Object { id=    
"3"    
, genre_name=    
"Action"    
}       
3
    Object { id=    
"4"    
, genre_name=    
"Mystery"    
}