Lev*_*ith 13 ajax extjs ext-direct
Ext.direct比常规Ext.ajax调用有哪些主要优点?我什么时候应该考虑使用另一个?
pha*_*kat 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'
});
Run Code Online (Sandbox Code Playgroud)
商店将要求服务器调用所述方法,服务器将给商店提供响应.你可以做一些整洁的事情,拥有一个随时可用和暴露的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'
}
}
});
Run Code Online (Sandbox Code Playgroud)
我希望这会给你一些观点,但实际上你应该了解每个人的工作方式,并应用最适合你和你的情况的解决方案.阅读两者的Ext API页面是一个很好的起点,Sample和Demos页面提供了两者的示例.
归档时间: |
|
查看次数: |
7284 次 |
最近记录: |