13

与常规 Ext.ajax 调用相比,Ext.direct 的主要优势是什么?我什么时候应该考虑使用其中一个?

4

1 回答 1

13

实际上,这取决于您的后端、您想要做什么以及适合您的情况。你提出的问题相当模糊,所以我的回答恐怕只能为你做这么多。您可以做的最好的事情是查看 Ext.Direct 和 Ext.Ajax 的 API 页面。Ext.Direct (我上次查看时)有很好的文档记录,.Ajax 也是如此,但是.Ajax 没有太多内容。

Ext.Direct - 我在上一份工作中开始实施这个,总而言之,它是一个启动和运行的 PITA,但之后的好处非常好。Ext.Direct 允许您调用服务器以执行方法,这些方法被定义为您以 JSON 对象的形式传递给 Ext 的 API。然后将这些方法公开给您的应用程序:

 // Server-side
 class MyDirectRouter
 {
     public function GetNames(){
        // Get some names from the database
        return $names;
     }
 }

 // Client-side - also, not sure on exact configs here so 
 // you should do your homework
 var store = Ext.create('Ext.data.DirectStore', {
   // blah blah configs
   proxy: {
       url: '/my/direct/router/GetNames',
       type: 'direct'
 });

商店将要求服务器调用所述方法,服务器将给商店响应。您可以做一些简洁的事情,并且拥有一个现成的和公开的 API 可以为您节省很多设置自定义路由、控制器等的麻烦。

Ext.Ajax 这个名字说明了一切:AJAX。调用服务器上的页面并返回响应。这里的主要区别是这调用了一个页面,而不是一个方法。页面可以做很多事情(当然,方法也可以),但页面负责格式化输出 - JSON、XML 等。服务器端Direct方法最终也会格式化输出,但通常会编写一个路由器来处理方法的调用和输出格式化。Ext.Ajax 更容易处理,因为它几乎不需要任何设置,除了在另一端处理 AJAX 请求的页面,而 Direct 需要一些后端类来处理路由、API 公开等。有插件对于不同的框架(Kohana、CodeIgnitor,可能是 WordPress 等),并且自己滚动可能并不困难。为了公平起见,以 Ext.Ajax 为例:

// Server-side - code of /ajax.php
echo(json_encode(array(
    'DATA' => array(
        array('id' => 3, 'name' => 'john'), 
        array('id' => 4, 'name' => 'Jill')
     )
));

// Client-side
var store = Ext.create('Ext.data.Store', {
    fields: ['id', 'name'], // You should really use a model
    proxy: {
        type: 'ajax',
        url: '/ajax.php',
        reader: {
            type: 'json',
            root: 'DATA'
        }
    }
});

我希望这能给你一些观点,但实际上你应该了解每一个是如何工作的,并应用最适合你和你的情况的解决方案。阅读两者的 Ext API 页面是一个很好的起点,示例和演示页面提供了两者的示例。

于 2012-04-19T20:37:31.803 回答