`
trace
  • 浏览: 125467 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Dojo Helloworld分析

阅读更多

昨天研究了一下dojo的helloworld,将一些心得记录如下。


dojo的加载有四步,顺序一定不能颠倒。

1、加载dojo配置

 
  1. <script type="text/javascript">  
  2. var djConfig = {  
  3.         bindEncoding: 'UTF-8'  
  4. };  
  5. </script>  

2、导入dojo.js文件

 
  1. <script type="text/javascript" src="js/dojo/dojo.js"></script>  

、自定义函数

<script>…………….</script>

4、定义初始加载函数

 
  1. //接在上面的脚本中  
  2. function initMethod()  
  3. {  
  4.        var helloButton = dojo.widget.byId('helloButton');  
  5.    ojo.event.connect(helloButton, 'onClick', 'helloPressed');  
  6. }  
  7. dojo.addOnLoad(initMethod);  

 

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

 

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

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

 

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

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

 
  1. function helloPressed()  
  2. {  
  3.         dojo.io.bind({  
  4.   
  5.                        url: 'Operator.jsp',  
  6.   
  7.                        load: helloCallback,  
  8.   
  9.                        error: helloCallbackError,  
  10.   
  11.                        content: {user: dojo.byId('name').value }  
  12.   
  13.                     });  
  14. }  

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

 

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

也是定义helloPressed函数,具体内容如下:

 
  1. function helloPressed()  
  2.           dojo.io.bind({  
  3.                          url: 'Operator.jsp',  
  4.                          load: helloCallback,  
  5.                          error: helloCallbackError,  
  6.                        ///formNode属性只不过是将表单中的参数全部读出,然后由dojo.io.bind来  
  7.                        ///传送到服务器端(以post的形式),表单并没有被提交。  
  8.                        formNode: dojo.byId('myForm')  
  9.                     });  
  10. }  

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


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


下面来看看helloCallbackhelloCallbackError函数:


1helloCallback函数

 
  1. function helloCallback(type, data, evt)  
  2. {  
  3.                   alert(data);  
  4.                   ///alert(evt instanceof XMLHttpRequest);  
  5. }  

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


2helloCallbackError函数

 
  1. function helloCallbackError(type, error) {  
  2.   
  3.                       alert("Error when retrieving data from the server!")  
  4.   
  5. }  

这个函数的参数同样也是固定的。

 

最后,来说一说用getpost方法与服务器通信时,中文问题的解决。

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

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

  • 源码.rar (2.2 KB)
  • 描述: 主要页面及Servlet源码
  • 下载次数: 533
分享到:
评论
8 楼 reasonsoft 2007-08-09  
好东西,谢谢,dojo还要学啊
7 楼 reasonsoft 2007-08-09  
oppopp
6 楼 ahut9923 2007-07-16  
效果就像我们写快速回复时候,当你提交时,在提交按钮旁边出现的提示
5 楼 ahut9923 2007-07-16  
楼上,loading效果是当提交一个数据的时候,页面提示“数据提交中....”,当用户再次提交的时候,提示用户操作还没结束,不能继续提交。
4 楼 Tin 2007-07-16  
loding...的效果是出现指示条么?
你需要在io.bind的时候让这个div的display为none。
在callback的时候让display为""。
即可。
formNode的方式是使用dojo默认的序列化,如果你需要可以自己定义bind的函数,然后自己调用dojo的序列化表格功能就可以了。
3 楼 ahut9923 2007-07-16  
我用dojo.io.bind函数的返回值实现loading效果,但是感觉又感觉不是很对! 能把自己写的js代码发一份给我吗?ahut9923@126.com
2 楼 trace 2007-07-13  
loading...效果,用自己写的js代码很好办,但在dojo里面怎么做我还不知道,实在抱歉。
1 楼 ahut9923 2007-07-12  
上面的代码着实给了我很大的帮助,请问楼主,怎么样实现提交时候的"loading......"效果?

相关推荐

    Dojo Hello World

    【标题】"Dojo Hello World" 是一个针对初学者的教程,主要介绍如何在Web开发中使用Dojo JavaScript库创建一个简单的"Hello, World!"示例。Dojo是一个功能强大的JavaScript框架,它提供了丰富的工具集,包括UI组件、...

    dojo服务器推送技术的HelloWorld例子

    本“dojo服务器推送技术的HelloWorld例子”旨在帮助初学者理解如何使用Dojo和Comet技术来实现实时通信。下面我们将深入探讨这两个关键概念。 1. **Dojo框架**: Dojo是一个开源的JavaScript库,提供了丰富的功能和...

    Struts2_HelloWorld例子

    这个"Struts2_HelloWorld"例子是初学者踏入Struts2世界的绝佳起点,它通过一个简单的实例展示了如何在Struts2框架下创建并运行一个基本的Web应用。 首先,我们来看"HelloWorld"的实现过程。在Struts2中,我们通常会...

    dojo例子 各方法的用法

    在这个"dojo例子 各方法的用法"的压缩包中,我们很可能会找到关于如何使用Dojo库的各种示例,包括"HelloWorld"这样的基础入门教程以及其他复杂功能的演示。 首先,让我们了解一下Dojo的核心概念。Dojo的基础模块`...

    dojo快速入门文档

    |+--dojo_hello_world.html| ``` 其中 `dojo.js` 文件位于 `dojo-lib/dojo/` 目录下。要在 HTML 页面中引用 Dojo,需要在页面头部添加以下代码: ```html &lt;script type="text/javascript" src="./dojo-lib/dojo/...

    HelloDoJo

    在学习任何新的编程库或框架时,创建“Hello, World!”类型的程序是常见的起点,它帮助开发者理解如何引入库,并执行最基本的交互。 尽管没有具体的标签,我们可以假设这个压缩包可能包含以下内容: 1. **dojo.js*...

    dojo-helloworld-java

    示例Java应用Docker和Kubernetes dojos 将HELLO_ENV环境变量设置为任何值,以设置8080端口上显示的消息。 默认值为“默认”。

    dojo对DOM树的关于byid() pdf格式

    dojo.byId("someNode").innerHTML = "Hello World"; ``` 上述代码将ID为`"someNode"`的DOM元素的`innerHTML`属性设置为`"Hello World"`。 2. **条件判断** 当我们不确定页面上是否存在某元素时,可以使用`...

    dojo 之基础篇(二)之从服务器读取数据

    本例子沿用 “dojo 之基础篇” 中的内容首先,我们在HelloWorld.html的同一级目录,新建一个文件,名为response.txt,内容为:Welcome to the Dojo Hello World Tutorial将section 2的代码替换 为以下代码 &lt;...

    dojo初学者文档

    dojo初学者文档,叫你怎么打出hello world!

    the book of dojo

    本书第六页开始介绍了“Hello World”示例,这是Dojo初学者必经之路。通过这个简单的例子,读者可以快速了解如何使用Dojo创建基本的交互式元素。例如,可以实现一个按钮点击后显示一段文本的功能,这个过程不仅简单...

    dojo学习笔记

    - **示例**:`dojo.connect(dojo.byId('helloBtn'), 'onclick', function(){ alert("Hello world!"); });` #### 三、Dojo的使用步骤 1. **引入CSS样式表**: - **代码**: ```html @import "js/dijit/themes...

    dojo 之基础篇

    &lt;title&gt;Dojo:HelloWorld! &lt;!--SECTION1--&gt; &lt;script type="text/javascript" src="js/dojo/dojo.js"&gt; &lt;!--SECTION2--&gt; &lt;button dojoType="Button" widgetId="helloButton"&gt;HelloWorld! ``` - **`...

    Struts2 例子.

    在这个例子中,`helloWorld` Action与`/HelloWorldAction` URL关联,使用`execute`方法执行,并且当方法成功执行后,会显示`HelloWorld.jsp`页面。 Struts2的拦截器(Interceptor)是另一个关键特性,它们在Action...

    dojo 之基础篇(三)之向服务器发送数据

    ### Dojo 基础篇(三):向服务器发送数据 #### 一、概述 在Web开发中,客户端与服务器端之间...更多关于Dojo的信息和高级用法,请访问[Dojo官方文档](http://dojo.jot.com/WikiHome/Tutorials/HelloWorld)进行学习。

    麻雀虽小五脏俱全 Dojo自定义控件应用

    dojo.declare("hello.world", [dijit._Widget, dijit._Templated], { // 控件模板 templateString: "你好,世界!&lt;/div&gt;", // 构造函数 constructor: function(params, node) { // 初始化逻辑 }, // 控件...

    Struts2 国际化字符串 拦截器

    &lt;action name="VMHelloWorld" class="tutorial.HelloWorld"&gt; &lt;result type="velocity"&gt;/HelloWorld.vm 例3 classes/struts.xml中VMHelloWorld Action的配置 新建HelloWorld.vm,内容如下所示: &lt;title&gt;...

Global site tag (gtag.js) - Google Analytics