Dojo Helloworld分析
关键字: dojo ajax helloworld昨天研究了一下dojo的helloworld,将一些心得记录如下。
dojo的加载有四步,顺序一定不能颠倒。
|
1、加载dojo配置 |
|
|
2、导入dojo.js文件 |
|
|
、自定义函数 |
<script>…………….</script> |
|
4、定义初始加载函数 |
|
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方法调用就展示完毕了。
下面来看看helloCallback和helloCallbackError函数:
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编码。
在更复杂的应用中(比如连接数据库),若发现有乱码问题,那么一定是服务器端的问题,通过在服务器端的程序中改变编码格式,就可以解决。
评论
你需要在io.bind的时候让这个div的display为none。
在callback的时候让display为""。
即可。
formNode的方式是使用dojo默认的序列化,如果你需要可以自己定义bind的函数,然后自己调用dojo的序列化表格功能就可以了。
- 浏览: 40711 次
- 性别:

- 来自: 武汉

- 详细资料
搜索本博客
我的相册
共 8 张
最新评论
-
如果有两处分页……
谢谢了!一上google马上找到了!
-- by llleelay -
db:migrate时,Table alre ...
学习了,我以前也经常出现这种问题,只知道不行了用version重新来。看来要好好 ...
-- by mirway -
搞定dojo引起的ie6“无法 ...
hax 写道有啥不同啊? 计算绝对地址的时候结果不同。 另外,base已经是xh ...
-- by jindw -
搞定dojo引起的ie6“无法 ...
有啥不同啊?
-- by hax -
搞定dojo引起的ie6“无法 ...
确实。一旦有<base href="<%=basePath%>"> ...
-- by jindw






评论排行榜