dojo初解和dojo.connect用法(转)
最近在学习arcgis javascript api,javascript api是基于Dojo,所以先熟悉一下Dojo。
DOJO常用的:
1,通过dojo.require以类似C编程中#include或者Java中import的方式加载所需的部件
如dojo.require("dojo.parser");dojo.require("dijit.form.Button");
2,跨域自定义模块
Dojo配置,djConfig="baseUrl:'./'"
注册模块的路径,dojo.registerModulePath("dtdg","./dtdg");
加载自定义模块,dojo.require("dtdg.foo");
3,本地工具箱模块
直接加载自定义模块,dojo.require("dtdg.foo");
4,为对象注册事件
dojo.connect();
5,json和字符串之间转换
dojo.fromJson( json);//返回JavaScript对象,json对象
dojo.toJson( json, prettyPrint);//返回字符串
6,Ajax通信
dojo.xhrGet( args);dojo.xhrPost( args);
dojo.xhr( method, args, hasBody);
7,本地化
djConfig="dojo.local:'zh'"
8,控件、布局等都在dijit中
介绍
参数
类型
描述
obj
Object|null
事件关联的对象。最常见的是DOM node,关联的事件会被委托到DOM事件管理器(除非dontFix为true);也可以是其他JavaScript Object;或者干脆就是null,这时就是默认为dojo.global
event
String
上面obj需要关联的事件的名称。比如DOM node的”onclick”之类的。
context
Object|null
前面两个参数讲的都是关联的“源”,这儿开始就是讲关联的“目标”了。context为后面的method提供了执行上下文环境,相当于method的this。如果context为null且method是一个function,则method会继承event的context。如果method是一个string,则context必须是method的源对象。如果context为null,则默认为dojo.global。
method
String|Function
当event被触发后调用的目标函数。可以是函数引用,或者context中的函数名称。此method会拿到和事件同样的参数。
dontFix
Boolean
可选项。如果obj参数是DOM node,当设置dontFix为true时,可以阻止关联被委托到DOM事件管理器。(貌似很强大的功能)
关联事件,不仅仅是DOM Event
function a(){ console.log("a") }; function b(){ console.log("b"); } dojo.connect(null,"a",null,b); a();
执行结果:a
<</span>html><</span>head><</span>title>Test dojo.connect</</span>title><</span>link rel="stylesheet" type="text/css" href="js/dojo-1.5.0/dijit/themes/dijit.css" mce_href="js/dojo-1.5.0/dijit/themes/dijit.css"></</span>link><</span>link rel="stylesheet" type="text/css" href="js/dojo-1.5.0/dijit/themes/tundra/tundra.css" mce_href="js/dojo-1.5.0/dijit/themes/tundra/tundra.css"></</span>link><</span>mce:script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js" mce_src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js" djConfig="parseOnLoad:false"></</span>mce:script><</span>mce:script type="text/javascript"></</span>mce:script></</span>head><</span>body class="tundra"><</span>div style="width: 800px; height: 200px"><</span>div dojoType="dijit.layout.TabContainer" style="width: 100%; height: 100%;"><</span>div dojoType="Test" title="Space" id="cp"><</span>div style="background-color:yellow;display:none;" mce_style="background-color:yellow;display:none;" id="showMsg"></</span>div><</span>br/> Please input your mostly used dojo object: <</span>br/><</span>input type="text" id="text"/><</span>br/><</span>input type="button" id="save" value="Save"/></</span>div></</span>div></</span>div></</span>body></</span>html>
这儿dojo.connect(this,"save",null,this.showMsg)中,由于save函数属于Test,因此dojo.connect的第一个参数必须指定save的对象是this。第二个参数给定关联的事件为save。第四个参数也需要指定正确的关联目标事件,也就是this中的showMsg函数。还有一种等价的写法就是:dojo.connect(this,"save", this,”showMsg”)。
<</span>html><</span>head><</span>title>Test Startup</</span>title><</span>link rel="stylesheet" type="text/css" href="js/dojo-1.5.0/dijit/themes/dijit.css" mce_href="js/dojo-1.5.0/dijit/themes/dijit.css"></</span>link><</span>link rel="stylesheet" type="text/css" href="js/dojo-1.5.0/dijit/themes/tundra/tundra.css" mce_href="js/dojo-1.5.0/dijit/themes/tundra/tundra.css"></</span>link><</span>mce:script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js" mce_src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js" djConfig="parseOnLoad:false"></</span>mce:script><</span>mce:script type="text/javascript"></</span>mce:script></</span>head><</span>body class="tundra"><</span>div style="width: 800px; height: 200px"><</span>div dojoType="dijit.layout.TabContainer" style="width: 100%; height: 100%;"><</span>div dojoType="Test" title="Space" id="cp"><</span>div style="background-color:yellow;display:none;" mce_style="background-color:yellow;display:none;" id="showMsg"></</span>div><</span>br/> Please input your mostly used dojo object: <</span>br/><</span>input type="text" id="text"/><</span>br/><</span>input type="button" id="reset" value="Reset"/><</span>input type="button" id="save" value="Save"/></</span>div></</span>div></</span>div></</span>body></</span>html>
var list = [ { func:"save", msg:"You are saving your mostly used dojo object..." }, { func:"reset", msg:"Your input is reset" }]; var that = this; dojo.forEach(list, function(item){ dojo.connect(that, item.func, item, that.showMsg); });
转自:http://www.voidcn.com/article/p-txkcxyvw-gd.html