dwr-engine.js

engine.js Functions

engine.js对DWR非常重要,因为它是用来转换来至动态生成的接口的javascript函数调用的,所以只要用到DWR的地方就需要它。

The engine.js file

每一个页面都需要下面这些语句来引入主DWR引擎。

<script type"text/javascript" 
src="/[YOUR-WEB-APP]/dwr/engine.js"> 
</script>

使用选项

下面这些选项可以通过 DWREngine.setX() 函数来设置全局属性。例如:

DWREngine.setTimeout(1000);

或者在单次调用级别上(假设Remote被DWR暴露出来了):

Remote.singleMethod(params, { 
callback:function(data) { ... }, 
timeout:2000 
});

远程调用可以批量执行来减少反应时间。endBatch 函数中可以设置选项。

DWREngine.beginBatch(); 
Remote.methodInBatch1(params, callback1); 
Remote.methodInBatch2(params, callback2); 
DWREngine.endBatch({ 
timeout:3000 
});

可以混合这几种方式,那样的话单次调用或者批量调用级别上的设置可以复写全局设置(就像你希望的那样)。当你在一个批量处理中多次设置了某个选项,DWR会保留最后一个。所以如果 Remote.singleMethod() 例子在batch里面,DWR会使用3000ms做为超时的时间。

callback和exceptionHandler两个选项只能在单次调用中使用,不能用于批量调用。

preHook和postHook选项两个选项是可添加的,就是说你可以为每一次调用添加多个hook。全局的preHook会在批量调用和单次调用之前被调用。同样全局的postHook会在单次调用和批量调用之后被调用。

如果以上叙述让你感到混乱,不用担心。DWR的的设计往往和你想象中的一样,所以其实这些并不复杂。

选项索引

下面是可用选项列表。

OptionGlobalBatchCallSummary
async1.11.11.1设置是否为异步调用,不推荐同步调用
headers2.02.02.0在XHR调用中加入额外的头信息
parameters2.02.02.0可以通过Meta-datarequest.getParameter()取得的元数据
httpMethod2.02.02.0选择GET或者POST. 1.x中叫&apos;verb&apos;
rpcType2.02.02.0选择是使用xhr, iframe或者script-tag来实现远程调用. 1.x中叫&apos;method&apos;
skipBatch1.0*2.1?-某个调用是否应该设置为batch中的一部分或者直接的。这个选项和上面都有些不同。
*没有setSkipBatch()方法,批量调用是通过beginBatch()和endBatch()来控制的。
timeout1.01.11.1设定超时时长,单位ms

处理器(Handler)

OptionGlobalBatchCallSummary
errorHandler1.01.11.1当出了什么问题时的动作。1.x中还包括服务端的异常。从2.0开始服务端异常通过&apos;exceptionHandler&apos;处理
warningHandler1.02.02.0当因为浏览器的bug引起问题时的动作,所以默认这个设置为null(关闭)
textHtmlHandler2.02.02.0当得到不正常的text/html页面时的动作(通常表示超时)

调用处理器(Call Handler) (注册到单独调用上的,而不是batch中的所有调用)

OptionGlobalBatchCallSummary
callback--1.0调用成功以后的要执行的回调函数,应该只有一个参数:远程调用得到的数据
exceptionHandler--2.0远程调用失败的动作,一般是服务端异常或者数据转换问题。

Hooks (一个batch中可以注册多个hook)

OptionGlobalBatchCallSummary
preHook1.01.11.1远程调用前执行的函数
postHook1.01.11.1远程调用后执行的函数

全局选项(在单次调用或者批量调用中不可用)

OptionGlobalBatchCallSummary
ordered1.0--DWR是否支持顺序调用
pollType2.0--选择xhr或者iframe的反转Ajax
reverseAjax2.0--是否查找inbound调用

废弃的选项

OptionGlobalBatchCallSummary
verb1.01.11.12.0废弃。使用&apos;httpMethod&apos;代替
method1.01.11.12.0废弃。使用&apos;rpcType&apos;代替

将来的

OptionGlobalBatchCallSummary
onBackButton2.1?2.1?-用户按了back按钮后的动作
onForwardButton2.1?2.1?-用户按了forward按钮的动作

保证的责任

DWR的目的是让你确切的知道所有调用的动作。知道了浏览器存在的bug,这是可以做到了。

如果你设置了callback, exceptionHandler, errorHandler, warningHandler 和 textHtmlHandler,DWR就应该 总是 为每一个请求提供响应。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值