Dojo Hello World

from: http://www.iteye.com/topic/91579

dojo的加载有四步,顺序一定不能颠倒。
[b]1、加载dojo配置[/b]
<script type="text/javascript">   
var djConfig = {
bindEncoding: 'UTF-8'
};
</script>


[b]2、导入dojo.js文件[/b]
<script type="text/javascript" src="js/dojo/dojo.js"></script>  


[b]3.自定义函数[/b]
<script>…………….</script>


[b]4、定义初始加载函数[/b]
//接在上面的脚本中
function initMethod()   
{
var helloButton = dojo.widget.byId('helloButton');
ojo.event.connect(helloButton, 'onClick', 'helloPressed');
}
dojo.addOnLoad(initMethod);


Hellword的例子中,主线是一个button,通过它触发三个不同的函数,来实现三个典型的dojo调用,以下分别叙述:

1、直接弹出对话框。(直接调用客户端的JavaScript函数)

定义helloPressed函数,直接调用alert方法就可以了。

2、用get方法与后台通信。

同样是定义helloPressed函数,其具体内容如下:


function helloPressed()   
{
dojo.io.bind({

url: 'Operator.jsp',

load: helloCallback,

error: helloCallbackError,

content: {user: dojo.byId('name').value }

});
}


与后台通信,关键的调用就是这个dojo.io.bind。其中的url就不说了,load表示得到响应后的处理函数,error表示服务器端报错后的处理函数,content表示的就是get方法要传送的内容,其中,user表示变量名,在后台可以用getParameter("user")来取得变量值,user后面的就是变量值了。

3、用post方法与后台通信。

也是定义helloPressed函数,具体内容如下:
function helloPressed()   
{
dojo.io.bind({
url: 'Operator.jsp',
load: helloCallback,
error: helloCallbackError,
///formNode属性只不过是将表单中的参数全部读出,然后由dojo.io.bind来
///传送到服务器端(以post的形式),表单并没有被提交。
formNode: dojo.byId('myForm')
});
}



可以看到,这里不同的仅仅是formNode属性。这个属性指定了一个要传输的form。在试验中我发现,被指定的form并没有被提交,而只是dojo.io.bind提取了form中的变量,然后用自己的方法提交到了服务器端。

至此,三个典型的dojo方法调用就展示完毕了。

[b]下面来看看helloCallback和helloCallbackError函数:[/b]
1、helloCallback函数

 
function helloCallback(type, data, evt)
{
alert(data);
///alert(evt instanceof XMLHttpRequest);
}

这个函数的参数都是特定的。其中,data是从服务器端传回的文本,evt是一个XMLHttpRequest变量。

2、helloCallbackError函数
function helloCallbackError(type, error) {   

alert("Error when retrieving data from the server!")

}



这个函数的参数同样也是固定的。
最后,来说一说用get或post方法与服务器通信时,中文问题的解决。

在Operator.jsp这个页面中,不需要设置任何的编码信息,就可以正确显示中文。在这里,dojo的客户端程序中,只能用UTF-8编码。

在更复杂的应用中(比如连接数据库),若发现有乱码问题,那么一定是服务器端的问题,通过在服务器端的程序中改变编码格式,就可以解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值