`
zhaosoft
  • 浏览: 187019 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

dojo快速入门

阅读更多
转载请注明出处 http://www.fyting.com,谢谢
2006年初,dojo还是0.22的时候就很关注它的发展,可一直没有在实际项目中使用。一来是由于文档的缺少,而来是dojo的相关介绍总是让人望而生畏。到现在都如此,第一个hello world就搞了一大堆东西,比如widget组件,自定义的script标签等,加上要引入什么css文件,djConfig、 dojo.require等等,让人很迷惑,这么复杂,到底dojo该怎么使用呢?我只是想把dojo当作一个普通的js类库,就像prototype那样?OK,闲话少说,来看看如何使用dojo。

第一步,引入dojo.js
dojo的发行包里有4个子目录,要引入的文件是名叫"dojo"的子目录里的dojo.js。
假设你是这样的目录结构:
引用

project
|
+--dojo-lib
| |
| +--dijit
| +--dojo
| +--dojox
| +--util
|
+--dojo_hello_world.html


Java代码 复制代码
  1. <script type="text/javascript" src="./dojo-lib/dojo/dojo.js"></script>  
Java代码 复制代码
  1. <script type="text/javascript" src="./dojo-lib/dojo/dojo.js"></script>  
<script type="text/javascript" src="./dojo-lib/dojo/dojo.js"></script>




开始使用dojo
现在开始使用dojo的第一个函数:dojo.byId
dojo.byId就等同于常用的document.getElement
<input type="text" name="username" id="username" value="Mark" />
<script type="text/javascript">
var username = dojo.byId('username').value
alert(username);
</script>
OK,是不是和普通的js库一样,没有任何玄机?



dojo.addOnLoad
现在我们想在window.onload里面处理一点东西,就像Ext.onReady,这个东西在dojo里叫做dojo.addOnLoad
Java代码 复制代码
  1. dojo.addOnLoad(function(){  
  2.     var username = dojo.byId('username').value  
  3.     alert(username);  
  4. });  
Java代码 复制代码
  1. dojo.addOnLoad(function(){  
  2.     var username = dojo.byId('username').value  
  3.     alert(username);  
  4. });  
dojo.addOnLoad(function(){
	var username = dojo.byId('username').value
	alert(username);
});




dojo.connect
OK,window.onload搞定了,那么如何监听普通的dom事件呢?没问题,强大的dojo.connect出场
Java代码 复制代码
  1. <script type="text/javascript">  
  2. function sayHello(event)  
  3. {  
  4.     alert("Hello");  
  5. }  
  6. dojo.addOnLoad(function(){  
  7.     var btn = dojo.byId('hello');  
  8.     dojo.connect(btn,"onclick",sayHello);  
  9. });  
  10. </script>  
  11. <input type="button" id="hello" value="Hello" />  
Java代码 复制代码
  1. <script type="text/javascript">  
  2. function sayHello(event)  
  3. {  
  4.     alert("Hello");  
  5. }  
  6. dojo.addOnLoad(function(){  
  7.     var btn = dojo.byId('hello');  
  8.     dojo.connect(btn,"onclick",sayHello);  
  9. });  
  10. </script>  
  11. <input type="button" id="hello" value="Hello" />  
<script type="text/javascript">
function sayHello(event)
{
	alert("Hello");
}
dojo.addOnLoad(function(){
	var btn = dojo.byId('hello');
	dojo.connect(btn,"onclick",sayHello);
});
</script>
<input type="button" id="hello" value="Hello" />


是不是和prototype的Event.observe($('btnAdd'), "load", doAdd)差不多?
用prototype时最烦的就是那个长长的bindAsListener了,使用dojo.conncect,可以在第三个参数中指定当前的scope:
Java代码 复制代码
  1. var name = "Mark"  
  2. function sayHello()  
  3. {  
  4.     alert("Hello " + this.name);  
  5. }  
  6. var obj = {  
  7.     name: "Karl"  
  8. }  
  9. dojo.addOnLoad(function(){  
  10.     var btn = dojo.byId('hello');  
  11.     dojo.connect(btn,"onclick",obj,sayHello);//注意这行的第三个和第四个参数  
  12. });  
Java代码 复制代码
  1. var name = "Mark"  
  2. function sayHello()  
  3. {  
  4.     alert("Hello " + this.name);  
  5. }  
  6. var obj = {  
  7.     name: "Karl"  
  8. }  
  9. dojo.addOnLoad(function(){  
  10.     var btn = dojo.byId('hello');  
  11.     dojo.connect(btn,"onclick",obj,sayHello);//注意这行的第三个和第四个参数  
  12. });  
var name = "Mark"
function sayHello()
{
	alert("Hello " + this.name);
}
var obj = {
	name: "Karl"
}
dojo.addOnLoad(function(){
	var btn = dojo.byId('hello');
	dojo.connect(btn,"onclick",obj,sayHello);//注意这行的第三个和第四个参数
});

OK,点击按钮,将输出:Hello Karl
这里dojo.connect的第三个参数变成了scope,而handler函数是第四个,实际上
dojo.connect(btn,"onclick",sayHello);

dojo.connect(btn,"onclick",null,sayHello);
相同。
更加复杂的用法这里不作介绍,写太多就越搞越复杂了,后面再写文章详细介绍dojo.connect,这里只简单介绍如何绑定DOM事件。



xmlhttp dojo.xhrGet
OK,介绍了简单的DOM操作方法,接下来该到Ajax的传统项目-XmlHttp了
在使用xmlhttp时,需要注意到编码的问题,要让dojo默认绑定为utf-8怎么办呢?很简单,只需要修改一下引入dojo.js时的标签:

Java代码 复制代码
  1. <script type="text/javascript" src="./dojo-lib/dojo/dojo.js" djConfig="isDebug:true,bindEncoding:'UTF-8'"></script>  
Java代码 复制代码
  1. <script type="text/javascript" src="./dojo-lib/dojo/dojo.js" djConfig="isDebug:true,bindEncoding:'UTF-8'"></script>  
<script type="text/javascript" src="./dojo-lib/dojo/dojo.js" djConfig="isDebug:true,bindEncoding:'UTF-8'"></script>

多了一个djConfig属性,很简单,第一个isDebug是说是否打开FireBug的Console,第二个是xmlhttp使用的编码。第二个才是重点,设置了就一劳永逸了。

这次我们要点击了hello按钮后发出一个xmlhttp请求:
Java代码 复制代码
  1. function sayHello() {  
  2.     dojo.xhrGet({  
  3.         url: "http://localhost/hello/sayHello.jsp",  
  4.         handleAs: "text",  
  5.         load: function(responseText)  
  6.         {  
  7.           alert(responseText);  
  8.           dojo.byId("divHello").innerHTML = responseText;  
  9.         },  
  10.         error: function(response)  
  11.         {  
  12.           alert("Error");  
  13.         }  
  14.     });  
  15. }  
  16. dojo.connect(btn,"onclick",sayHello);  
Java代码 复制代码
  1. function sayHello() {  
  2.     dojo.xhrGet({  
  3.         url: "http://localhost/hello/sayHello.jsp",  
  4.         handleAs: "text",  
  5.         load: function(responseText)  
  6.         {  
  7.           alert(responseText);  
  8.           dojo.byId("divHello").innerHTML = responseText;  
  9.         },  
  10.         error: function(response)  
  11.         {  
  12.           alert("Error");  
  13.         }  
  14.     });  
  15. }  
  16. dojo.connect(btn,"onclick",sayHello);  
function sayHello() {
    dojo.xhrGet({
        url: "http://localhost/hello/sayHello.jsp",
        handleAs: "text",
        load: function(responseText)
        {
          alert(responseText);
          dojo.byId("divHello").innerHTML = responseText;
        },
        error: function(response)
        {
          alert("Error");
        }
    });
}
dojo.connect(btn,"onclick",sayHello);


看看,够不够一目了然?

url 就是url……
handleAs 把获取的内容作为text/html
load 成功时的回调函数
error 失败时的回调函数


那如果要传入参数怎么办?
Java代码 复制代码
  1. var params = {  
  2.     username:'Mark',  
  3.     id:'105'  
  4. }  
  5. dojo.xhrGet({  
  6.     url: "http://localhost/hello/sayHello.jsp",  
  7.     content:params,  
  8.     //...  
  9. });  
Java代码 复制代码
  1. var params = {  
  2.     username:'Mark',  
  3.     id:'105'  
  4. }  
  5. dojo.xhrGet({  
  6.     url: "http://localhost/hello/sayHello.jsp",  
  7.     content:params,  
  8.     //...  
  9. });  
var params = {
    username:'Mark',
    id:'105'
}
dojo.xhrGet({
    url: "http://localhost/hello/sayHello.jsp",
    content:params,
    //...
});

注意那个content参数,你要传入的参数是个关联数组/object,dojo会自动把参数解析出来,要使用post方法?
dojo.xhrGet ---> dojo.xhrPost
其他的还有
dojo.xhrPut
dojo.xhrDelete


json
那要是我想更换获取到的数据类型,比如json?xml?
修改handleAs即可,如:
handleAs: "json"
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     handleAs: "json",  
  4.     load: function(json)  
  5.     {  
  6.         alert(json.name)  
  7.     }  
  8.     //...  
  9. });  
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     handleAs: "json",  
  4.     load: function(json)  
  5.     {  
  6.         alert(json.name)  
  7.     }  
  8.     //...  
  9. });  
dojo.xhrGet({
    url: "http://localhost/hello/sayHello.jsp",
    handleAs: "json",
    load: function(json)
    {
        alert(json.name)
    }
    //...
});

引用

handleAs: "json-comment-filtered" 使用注释符号/**/把json数据包含起来,推荐使用
handleAs: "json-comment-optional" 首先尝试使用json-comment-filtered,如果执行错误,再使用普通的json格式解析
handleAs: "javascript" dojo尝试把服务器返回的数据当作javascript执行,并把结果作为参数传递给load函数
handleAs: "xml" xml对象。注意在Mozilla和IE中的xml是不同的,推荐使用sarissa


至于json和object的转换等,在http://dojotoolkit.org/book/dojo-book-0-9/part-3- programmatic-dijit-and-dojo/other-miscellaneous-function/converting-json 有一个表格,应该能找到你需要的。


想要直接提交一个表单,就这样:
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     form: dojo.byId("form1")  
  4.     //...  
  5. });  
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     form: dojo.byId("form1")  
  4.     //...  
  5. });  
dojo.xhrGet({
    url: "http://localhost/hello/sayHello.jsp",
    form: dojo.byId("form1")
    //...
});

要解决IE下那个臭名昭著的缓存问题,就这样,preventCache会帮你自动生成一个timestamp
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     preventCache: true  
  4.     //...  
  5. });  
Java代码 复制代码
  1. dojo.xhrGet({  
  2.     url: "http://localhost/hello/sayHello.jsp",  
  3.     preventCache: true  
  4.     //...  
  5. });  
dojo.xhrGet({
    url: "http://localhost/hello/sayHello.jsp",
    preventCache: true
    //...
});




dojo.hitch scope/context
既然用到了xmlhttp,一个常见的问题就是回调函数的scope/context。在prototype、mootools里我们常用Function.bind,在dojo中,做相同事情的东西叫做dojo.hitch
Java代码 复制代码
  1. var handler = {  
  2.     name:'Mark',  
  3.     execute1: function(){  
  4.         dojo.xhrGet({  
  5.             url: "http://localhost/hello/sayHello.jsp",  
  6.             handleAs: "text",  
  7.             error: function(text)  
  8.             {  
  9.                 console.dir(this);  
  10.                 alert(this.name);//输出undefined,这里的this表示当前io参数  
  11.             }  
  12.             //...  
  13.         });  
  14.     },  
  15.     load: function(text){  
  16.         alert(this.name);  
  17.     },  
  18.     execute2: function(){  
  19.         dojo.xhrGet({  
  20.             url: "http://localhost/hello/sayHello.jsp",  
  21.             handleAs: "text",  
  22.             error: dojo.hitch(this,"load"//输出Mark   
  23.             //error: dojo.hitch(this,this.load); //与上一句相同,知道为什么要用方法名字而不是引用了吧?省去了长长的一串this.xxx  
  24.             //...  
  25.         });  
  26.     }  
  27. }  
Java代码 复制代码
  1. var handler = {  
  2.     name:'Mark',  
  3.     execute1: function(){  
  4.         dojo.xhrGet({  
  5.             url: "http://localhost/hello/sayHello.jsp",  
  6.             handleAs: "text",  
  7.             error: function(text)  
  8.             {  
  9.                 console.dir(this);  
  10.                 alert(this.name);//输出undefined,这里的this表示当前io参数  
  11.             }  
  12.             //...  
  13.         });  
  14.     },  
  15.     load: function(text){  
  16.         alert(this.name);  
  17.     },  
  18.     execute2: function(){  
  19.         dojo.xhrGet({  
  20.             url: "http://localhost/hello/sayHello.jsp",  
  21.             handleAs: "text",  
  22.             error: dojo.hitch(this,"load"//输出Mark   
  23.             //error: dojo.hitch(this,this.load); //与上一句相同,知道为什么要用方法名字而不是引用了吧?省去了长长的一串this.xxx  
  24.             //...  
  25.         });  
  26.     }  
  27. }  
var handler = {
    name:'Mark',
    execute1: function(){
        dojo.xhrGet({
            url: "http://localhost/hello/sayHello.jsp",
            handleAs: "text",
            error: function(text)
            {
                console.dir(this);
                alert(this.name);//输出undefined,这里的this表示当前io参数
            }
            //...
        });
    },
    load: function(text){
        alert(this.name);
    },
    execute2: function(){
        dojo.xhrGet({
            url: "http://localhost/hello/sayHello.jsp",
            handleAs: "text",
            error: dojo.hitch(this,"load") //输出Mark 
            //error: dojo.hitch(this,this.load); //与上一句相同,知道为什么要用方法名字而不是引用了吧?省去了长长的一串this.xxx
            //...
        });
    }
}


OK,基本的东西解决了,还有很多常用的函数没有介绍,比如:dojo.query,dojo.forEach,dojo.marginBox,dojo.contentBox等等
这个就没事翻翻dojo.js.uncompressed.js源代码,dojo的文档是没啥好指望的了。



面向对象,定义Class
下一步我们看看dojo里如何定义Class:
Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     constructor:function(name){  
  3.         this.name = name;  
  4.     },  
  5.     say:function(){  
  6.         alert("Hello " + this.name);  
  7.     },  
  8.     getDiscount:function(){  
  9.         alert("Discount is 1.0");  
  10.     }  
  11. });  
  12.   
  13. var customer1 = new Customer("Mark");  
  14. customer1.say();  
Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     constructor:function(name){  
  3.         this.name = name;  
  4.     },  
  5.     say:function(){  
  6.         alert("Hello " + this.name);  
  7.     },  
  8.     getDiscount:function(){  
  9.         alert("Discount is 1.0");  
  10.     }  
  11. });  
  12.   
  13. var customer1 = new Customer("Mark");  
  14. customer1.say();  
dojo.declare("Customer",null,{
    constructor:function(name){
        this.name = name;
    },
    say:function(){
        alert("Hello " + this.name);
    },
    getDiscount:function(){
        alert("Discount is 1.0");
    }
});

var customer1 = new Customer("Mark");
customer1.say();

declare有三个参数:
第一个 class名字
第二个 父类的引用
第三个 ...

构造函数的名字就叫做"construnctor"


再来看看如何继承:

Java代码 复制代码
  1. dojo.declare("VIP",Customer,{  
  2.     getDiscount:function(){  
  3.         alert("Discount is 0.8");  
  4.     }  
  5. });  
  6. var vip = new VIP("Mark");  
  7. vip.say();  
  8. vip.getDiscount();  
Java代码 复制代码
  1. dojo.declare("VIP",Customer,{  
  2.     getDiscount:function(){  
  3.         alert("Discount is 0.8");  
  4.     }  
  5. });  
  6. var vip = new VIP("Mark");  
  7. vip.say();  
  8. vip.getDiscount();  
dojo.declare("VIP",Customer,{
    getDiscount:function(){
        alert("Discount is 0.8");
    }
});
var vip = new VIP("Mark");
vip.say();
vip.getDiscount();



那么,如何调用父类的方法呢。使用this.inherited方法

Java代码 复制代码
  1. dojo.declare("VIP",Customer,{  
  2.     getDiscount:function(){  
  3.         this.inherited(arguments);  
  4.         //this.inherited("getDiscount",arguments);  
  5.     }  
  6. });  
Java代码 复制代码
  1. dojo.declare("VIP",Customer,{  
  2.     getDiscount:function(){  
  3.         this.inherited(arguments);  
  4.         //this.inherited("getDiscount",arguments);  
  5.     }  
  6. });  
dojo.declare("VIP",Customer,{
    getDiscount:function(){
        this.inherited(arguments);
        //this.inherited("getDiscount",arguments);
    }
});



关于构造函数:
父类构造函数总是被自动调用的,所以看下面的例子:

Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     constructor:function(name){  
  3.         this.name = name;  
  4.         alert("base class");  
  5.     },  
  6.     say:function(){  
  7.         alert(this.name);  
  8.     }  
  9. });  
  10.   
  11. dojo.declare("VIP",Customer,{  
  12.     constructor:function(age){  
  13.         this.age = age;  
  14.         alert("child class");  
  15.     },  
  16.     say:function(){  
  17.         alert("name:" + this.name);  
  18.         alert("age:" + this.age);  
  19.     }  
  20. });  
  21.   
  22. var vip = new VIP("123");//1  
  23. vip.say();//2  
Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     constructor:function(name){  
  3.         this.name = name;  
  4.         alert("base class");  
  5.     },  
  6.     say:function(){  
  7.         alert(this.name);  
  8.     }  
  9. });  
  10.   
  11. dojo.declare("VIP",Customer,{  
  12.     constructor:function(age){  
  13.         this.age = age;  
  14.         alert("child class");  
  15.     },  
  16.     say:function(){  
  17.         alert("name:" + this.name);  
  18.         alert("age:" + this.age);  
  19.     }  
  20. });  
  21.   
  22. var vip = new VIP("123");//1  
  23. vip.say();//2  
dojo.declare("Customer",null,{
    constructor:function(name){
        this.name = name;
        alert("base class");
    },
    say:function(){
        alert(this.name);
    }
});

dojo.declare("VIP",Customer,{
    constructor:function(age){
        this.age = age;
        alert("child class");
    },
    say:function(){
        alert("name:" + this.name);
        alert("age:" + this.age);
    }
});

var vip = new VIP("123");//1
vip.say();//2

1将打印出两条alert语句,先是父类的构造函数,再是子类的。
2将输出"name: 123" "age: 123"
个人认为,这个特性并不好,因为javascript这种弱类型的语言中,根本无法确定构造函数中的参数是传递给谁的,就比如上面的语句执行后, name="123",age="123",那哪个才是正确的?这个问题在使用dojo Grid的model里就很麻烦,定义一个model得这样:new dojox.grid._data.Table(null,null,data);我要是想扩展这个Model,更麻烦,所有子类的构造函数都被父类给搞乱了。所以推荐的做法是使用关联数组作为构造函数的参数,就像Python里的关键字参数。

Java代码 复制代码
  1. constructor:function(args){  
  2.     var args = args || {};  
  3.     this.name = args.name;  
  4.     this.age = args.age;  
  5. }  
Java代码 复制代码
  1. constructor:function(args){  
  2.     var args = args || {};  
  3.     this.name = args.name;  
  4.     this.age = args.age;  
  5. }  
constructor:function(args){
    var args = args || {};
    this.name = args.name;
    this.age = args.age;
}



多继承,mixin
说到继承,多继承的问题又来了。dojo支持多继承,准确地说,是mixin。还记得dojo.declare的第二个参数吗,就是表示父类的那个参数,这个参数可以是一个数组,数组的第一个元素作为声明的类的父类,其他的作为mixin。子类自动获得父类和mixin的所有方法,后面的 mixin的同名方法覆盖前面的方法
Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     say:function(){  
  3.         alert("Hello Customer");  
  4.     },  
  5.     getDiscount:function(){  
  6.         alert("Discount in Customer");  
  7.     }  
  8. });  
  9.   
  10. dojo.declare("MixinClass",null,{  
  11.     say:function(){  
  12.         alert("Hello mixin");  
  13.     },  
  14.     foo:function(){  
  15.         alert("foo in MixinClass");  
  16.     }  
  17. });  
  18. dojo.declare("VIP",[Customer,MixinClass],{  
  19. });  
  20. var vip = new VIP();  
  21. vip.getDiscount();  
  22. vip.foo();  
  23. vip.say();//输出"Hello MixinClass"  
Java代码 复制代码
  1. dojo.declare("Customer",null,{  
  2.     say:function(){  
  3.         alert("Hello Customer");  
  4.     },  
  5.     getDiscount:function(){  
  6.         alert("Discount in Customer");  
  7.     }  
  8. });  
  9.   
  10. dojo.declare("MixinClass",null,{  
  11.     say:function(){  
  12.         alert("Hello mixin");  
  13.     },  
  14.     foo:function(){  
  15.         alert("foo in MixinClass");  
  16.     }  
  17. });  
  18. dojo.declare("VIP",[Customer,MixinClass],{  
  19. });  
  20. var vip = new VIP();  
  21. vip.getDiscount();  
  22. vip.foo();  
  23. vip.say();//输出"Hello MixinClass"  
dojo.declare("Customer",null,{
    say:function(){
        alert("Hello Customer");
    },
    getDiscount:function(){
        alert("Discount in Customer");
    }
});

dojo.declare("MixinClass",null,{
    say:function(){
        alert("Hello mixin");
    },
    foo:function(){
        alert("foo in MixinClass");
    }
});
dojo.declare("VIP",[Customer,MixinClass],{
});
var vip = new VIP();
vip.getDiscount();
vip.foo();
vip.say();//输出"Hello MixinClass"


其他的比较有用的函数就是dojo.mixin和dojo.extend了,顾名思义,一个是作用于对象实例,一个是用于扩展class,翻文档和源码吧。



package机制
说完了dojo里的类继承机制,不得不说说package机制。
主要用到的有
dojo.require
dojo.provide
dojo.registerModulePath


dojo.require
dojo.require就是引入相应路径文件下的js文件,现在已经有很多library这样做了。现在我们假设要用
project/dojo-lib/dojo/string.js

dojo中的顶层目录就是dojo.js所在目录的上一层,即"project/dojo-lib/",而dojo.js放在
project/dojo-lib/dojo/dojo.js
所以我们就这样:
dojo.require("dojo.string");
比如要引用其他目录下的:
project/dojo-lib/dojox/dtl/_base.js,则这样:dojo.require("dojox.dtl._base");

project/dojo-lib/dojox/grid/Grid.js dojo.require("dojox.grid.Grid");

说白了,就和ruby之类的require
分享到:
评论

相关推荐

    dojo快速入门(中文版)

    《dojo快速入门(中文版)》 dojo Toolkit是一个开源的JavaScript工具包,旨在简化Web应用的构建过程,提供高效且设计精良的API。它的轻量级特性(约26kb)和强大的功能集使得dojo在各种项目中都能灵活运用。核心功能...

    dojo快速入门文档

    ### Dojo 快速入门知识点详解 #### 一、Dojo 概览 Dojo 是一个功能强大且灵活的开源 JavaScript 库,主要用于构建高性能的富客户端 Web 应用程序。Dojo 提供了一系列工具和组件,使得开发者能够轻松创建交互式 Web...

    dojo快速入门.doc

    ### Dojo 快速入门详解 #### 一、Dojo Toolkit 概览 Dojo Toolkit 是一款开源的 JavaScript 工具包,专为构建现代化 Web 应用而设计。其核心价值在于通过提供一系列高质量的 API 和工具集,极大地简化了 Web 开发...

    Dojo快速入门教程

    ### Dojo快速入门教程 Dojo 是一个功能强大的面向对象 JavaScript 框架,它能够帮助开发者构建高性能、跨平台的 Web 应用程序。本教程将详细介绍 Dojo 的核心概念、基本用法以及如何利用 Dojo 开发 Web 应用。 ###...

    dojo新手快速入门教程-首发高清PDF中文版

    ### Dojo Toolkit:快速入门与理解 #### 一、引言 Dojo Toolkit是一个功能强大且灵活的开源JavaScript框架,专为构建现代化Web应用程序而设计。它的目标是简化Web开发,提供一系列工具来加速和优化Web应用的创建...

    dojo权威入门教程

    《dojo权威入门教程》是一本专注于JavaScript库Dojo Toolkit的学习指南,主要面向Java开发者或对Web前端技术感兴趣的人员。Dojo Toolkit是一个强大的JavaScript框架,它提供了丰富的组件、工具和API,帮助开发者高效...

    图书:Dojo入门

    《Dojo入门》这本书主要介绍了Dojo JavaScript库的使用,帮助初学者快速掌握这个强大的前端开发工具。Dojo是一个开源的JavaScript框架,旨在提供一站式的解决方案,包括UI组件、数据管理、动画效果、Ajax交互等功能...

    Dojo的一些学习资料

    "Dojo快速入门.pdf"可能会介绍Dojo的安装、配置过程,快速上手的方法,以及Dijit组件的初步使用。最后,"dojo组件的使用.pdf"将深入讲解Dijit的各种组件,如何配置、自定义以及在实际项目中应用它们。 通过这些学习...

    dojo入门实例介绍

    本文将通过一系列实例,帮助初学者快速掌握Dojo的核心概念和使用方法。 首先,理解Dojo的基础架构至关重要。Dojo采用AMD(Asynchronous Module Definition)模块化加载机制,允许开发者按需加载所需模块,提高页面...

    dojo技术入门ysk

    ### Dojo技术入门知识点概述 #### 一、Dojo简介 Dojo是一个开源的JavaScript工具包,主要用于构建富互联网应用(Rich Internet Applications, RIA)。它具有轻量级且易于安装的特点,在Web 2.0时代,随着Ajax技术...

    dojo的学习资料

    资源包中含有: 1.Dojo+API.doc 2.dojo快速入门.doc 3.Dojo中文手册.pdf 4.精通Dojo(中文版).pdf 5.Dojo案例:比如 ValidationTextBox、NumberTextBox、ContentPanel、dojoGrid等小例子。

    arcgis for js离线部署及dojo框架的入门

    ArcGIS for JS离线部署及Dojo框架入门 ArcGIS for JS是一个功能强大且流行的WebGIS开发框架,能够帮助开发者快速构建交互式的WebGIS应用程序。在这里,我们将讨论如何对ArcGIS for JS API进行离线部署,并介绍Dojo...

    Dojo Developer Guide (dojo 开发 指南)

    该指南适用于不同层次的开发者:服务器端开发者可以利用“无编码的小部件”快速构建应用;对于 HTML 和 CSS 开发者,Dojo 提供了丰富的模板驱动小部件设施;而对于高级 JavaScript 和 DHTML 开发者,Dojo 是一个强大...

    Dojo vs jQuery 比较

    由于其易用性,jQuery在Web开发中迅速普及,成为许多初学者入门JavaScript的首选工具。 在性能方面,Dojo通常被认为在大型复杂应用中表现更优,因为它采用延迟加载和模块化策略来减少脚本的体积。而jQuery虽然在小...

    dojo1.9 html格式的Reference Guide(参考手册)

    3. **Quickstart**:快速入门指南,是初学者了解Dojo的好起点,它提供了一套基本的教程和代码示例,帮助开发者快速搭建Dojo应用。 4. **Developer**:开发者部分通常涵盖Dojo的开发工具、调试技巧以及最佳实践,这...

    geting started with dojo

    ### Dojo 入门教程概览 #### 一、课程目标与内容介绍 - **课程目标**:本课程旨在帮助初学者快速掌握 Dojo 框架的基本使用方法,并能够运用该框架进行基本的 Web 开发工作。 - **课程内容**: - 第一天主要介绍 ...

    Dojo简单笔记和权威学习去处

    这里不仅有API参考,还有丰富的教程和示例,可以帮助初学者快速入门并深入理解Dojo的每一个角落。官方文档通常会详细介绍Dojo的加载器(dojo.require)、模块系统(dojo.declare)、声明式和程序化创建Widget的方式...

    精通dojo 3_2

    《精通Dojo》系列书籍分为三部,每部都针对不同层次的学习者设计,从入门到精通,帮助读者逐步掌握Dojo框架的核心技术和高级特性。本文将重点介绍该系列中的第二部,即《精通Dojo 3.2》部分。 #### 第二部主要内容...

    The book of Dojo 1.0

    #### 二、安装与快速入门 - **快速安装**:介绍如何快速安装 Dojo 并准备好开发环境。 - **Hello World 示例**:通过一个简单的“Hello World”示例来展示如何使用 Dojo 进行开发。 #### 三、调试教程 - **调试...

    技术基础:从头开始学习 Dojo

    Base 包的目的是使开发者能快速入门,提供必要的功能,如 DOM 查询和事件绑定。 2. **Core**:核心包包含了 Base 包之外的附加特性,如高级动画、拖放、I/O、数据管理、国际化和浏览器历史管理。这些特性虽然不是...

Global site tag (gtag.js) - Google Analytics