dojo入門筆記(免費(fèi))
《dojo入門筆記(免費(fèi))》由會員分享,可在線閱讀,更多相關(guān)《dojo入門筆記(免費(fèi))(10頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、2006年初,dojo還是0.22的時候就很關(guān)注它的發(fā)展,可一直沒有在實際項目中使用。一來是由于文檔的缺少,而來是dojo的相關(guān)介紹總是讓人望而生畏。 到現(xiàn)在都如此,第一個hello world就搞了一大堆東西,比如widget組件,自定義的script標(biāo)簽等,加上要引入什么css文件,djConfig、dojo.require等等,讓人很迷惑,這么復(fù)雜,到底dojo該怎么使用呢? 我只是想把dojo當(dāng)作一個普通的js類庫,就像prototype那樣?OK,閑話少說,來看看如何使用dojo。 第一步,引入dojo.js dojo的發(fā)行包里有4個子目錄,要引入的文件是名叫"dojo"
2、的子目錄里的dojo.js。 假設(shè)你是這樣的目錄結(jié)構(gòu):
project
|
+--dojo-lib
| |
| +--dijit
| +--dojo
| +--dojox
| +--util
|
+--dojo_hello_world.html
開始使用dojo
現(xiàn)在開始使用dojo的第一個函數(shù):dojo.byId ,dojo.byId就等同于常用的document.getElement 。
3、put type="text" name="username" id="username" value="Mark" />
OK,是不是和普通的js庫一樣,沒有任何玄機(jī)?
dojo.addOnLoad
現(xiàn)在我們想在window.onload里面處理一點東西,就像Ext.onReady,這個東西在dojo里叫做dojo.addOnLoad。
dojo.addOnLo 4、ad(function(){
?var username = dojo.byId('username').value
?alert(username);
});
dojo.connect
OK,window.onload搞定了,那么如何監(jiān)聽普通的dom事件呢?沒問題,強(qiáng)大的dojo.connect出場。
是不是和prototype的Event.observe($('btnAdd'), "load", doAdd)差不多? 用prototype時最煩的就是那個長長的bindAsListener了,使用dojo.conncect,可以在第三個參數(shù)中指定當(dāng)前的scope:
var name = "Mark"
function sayHello()
{
?alert("Hello 6、 " + this.name);
}
var obj = {
?name: "Karl"
}
dojo.addOnLoad(function(){
?var btn = dojo.byId('hello');
?dojo.connect(btn,"onclick",obj,sayHello);//注意這行的第三個和第四個參數(shù)
});
OK,點擊按鈕,將輸出:Hello Karl。這里dojo.connect的第三個參數(shù)變成了scope,而handler函數(shù)是第四個,實際上dojo.connect(btn,"onclick",sayHello); 與dojo.connect(b 7、tn,"onclick",null,sayHello); 相同。
更加復(fù)雜的用法這里不作介紹,寫太多就越搞越復(fù)雜了,后面再寫文章詳細(xì)介紹dojo.connect,這里只簡單介紹如何綁定DOM事件。
xmlhttp dojo.xhrGet
OK,介紹了簡單的DOM操作方法,接下來該到Ajax的傳統(tǒng)項目-XmlHttp了。在使用xmlhttp時,需要注意到編碼的問題,要讓dojo默認(rèn)綁定為utf-8怎么辦呢?很簡單,只需要修改一下引入dojo.js時的標(biāo)簽:
多了一個djConfig屬性,很簡單,第一個isDebug是說是否打開FireBug的Console,第二個是xmlhttp使用的編碼。第二個才是重點,設(shè)置了就一勞永逸了。 這次我們要點擊了hello按鈕后發(fā)出一個xmlhttp請求:
function sayHello() {
??? dojo.xhrGet({
??????? url: "http://localhost/hello/sayHello.jsp",
??????? handleAs: "text",
9、??????? load: function(responseText)
??????? {
????????? alert(responseText);
????????? dojo.byId("divHello").innerHTML = responseText;
??????? },
??????? error: function(response)
??????? {
????????? alert("Error");
??????? }
??? });
}
dojo.connect(btn,"onclick",sayHello);
看看,夠不夠一目了然? u 10、rl 就是url…… ;handleAs 把獲取的內(nèi)容作為text/html ;load 成功時的回調(diào)函數(shù);error 失敗時的回調(diào)函數(shù)
那如果要傳入?yún)?shù)怎么辦?
var params = {
??? username:'Mark',
??? id:'105'
}
dojo.xhrGet({
??? url: "http://localhost/hello/sayHello.jsp",
??? content:params,
??? //...
});
注意那個content參數(shù),你要傳入的參數(shù)是個關(guān)聯(lián)數(shù)組/object,dojo會自動把參數(shù)解析出來,要使用post方 11、法? dojo.xhrGet ---> dojo.xhrPost ,其他的還有,dojo.xhrPut、dojo.xhrDelete。
json
那要是我想更換獲取到的數(shù)據(jù)類型,比如json?xml?修改handleAs即可,如: handleAs: "json"
dojo.xhrGet({
??? url: "http://localhost/hello/sayHello.jsp",
??? handleAs: "json",
??? load: function(json)
??? {
??????? alert(json.name)
??? }
??? // 12、...
});
handleAs: "json-comment-filtered" 使用注釋符號/**/把json數(shù)據(jù)包含起來,推薦使用
handleAs: "json-comment-optional" 首先嘗試使用json-comment-filtered,如果執(zhí)行錯誤,再使用普通的json格式解析
handleAs: "javascript" dojo嘗試把服務(wù)器返回的數(shù)據(jù)當(dāng)作javascript執(zhí)行,并把結(jié)果作為參數(shù)傳遞給load函數(shù)
handleAs: "xml" xml對象。注意在Mozilla和IE中的xml是不同的,推薦使用sarissa
至于json和ob 13、ject的轉(zhuǎn)換等,在http://dojotoolkit.org/book/dojo-book-0-9/part-3-programmatic-dijit-and-dojo/other-miscellaneous-function/converting-json有一個表格,應(yīng)該能找到你需要的。
想要直接提交一個表單就這樣:
dojo.xhrGet({
??? url: "http://localhost/hello/sayHello.jsp",
??? form: dojo.byId("form1")
??? //...
});
要解決IE下那個臭名昭著的緩存問題,就這樣, 14、preventCache會幫你自動生成一個timestamp
dojo.xhrGet({
??? url: "http://localhost/hello/sayHello.jsp",
??? preventCache: true
??? //...
});
dojo.hitch scope/context
既然用到了xmlhttp,一個常見的問題就是回調(diào)函數(shù)的scope/context。在prototype、mootools里我們常用Function.bind,在dojo中,做相同事情的東西叫做dojo.hitch。
var handler = {
??? na 15、me:'Mark',
??? execute1: function(){
??????? dojo.xhrGet({
??????????? url: "http://localhost/hello/sayHello.jsp",
??????????? handleAs: "text",
??????????? error: function(text)
??????????? {
??????????????? console.dir(this);
??????????????? alert(this.name);//輸出undefined,這里的this表示當(dāng)前io參數(shù)
16、??????????? }
??????????? //...
??????? });
??? },
??? load: function(text){
??????? alert(this.name);
??? },
??? execute2: function(){
??????? dojo.xhrGet({
??????????? url: "http://localhost/hello/sayHello.jsp",
??????????? handleAs: "text",
??????????? error: dojo.hitch(this,"load") // 17、輸出Mark
??????????? //error: dojo.hitch(this,this.load); //與上一句相同,知道為什么要用方法名字而不是引用了吧?省去了長長的一串this.xxx
??????????? //...
??????? });
??? }
}
OK,基本的東西解決了,還有很多常用的函數(shù)沒有介紹,比如:dojo.query,dojo.forEach,dojo.marginBox,dojo.contentBox等等。這個就沒事翻翻dojo.js.uncompressed.js源代碼,dojo的文檔是沒啥好指望的了。
面向?qū)ο?定義Class
18、
下一步我們看看dojo里如何定義Class:
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("M 19、ark");
customer1.say();
declare有三個參數(shù): 第一個 class名字;第二個 父類的引用 ;第三個 ...
構(gòu)造函數(shù)的名字就叫做"construnctor"
再來看看如何繼承
dojo.declare("VIP",Customer,{
??? getDiscount:function(){
??????? alert("Discount is 0.8");
??? }
});
var vip = new VIP("Mark");
vip.say();
vip.getDiscount();
使用this.inherited方 20、法調(diào)用父類
dojo.declare("VIP",Customer,{
??? getDiscount:function(){
??????? this.inherited(arguments);
??????? //this.inherited("getDiscount",arguments);
??? }
});
關(guān)于構(gòu)造函數(shù)
父類構(gòu)造函數(shù)總是被自動調(diào)用的,所以看下面的例子:
dojo.declare("Customer",null,{
??? constructor:function(name){
??????? this.name = name;
?????? 21、? 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:" + 22、this.age);
??? }
});
var vip = new VIP("123");//1
vip.say();//2
1將打印出兩條alert語句,先是父類的構(gòu)造函數(shù),再是子類的。 2將輸出"name: 123" "age: 123" 。個人認(rèn)為,這個特性并不好,因為javascript這種弱類型的語言中,根本無法確定構(gòu)造函數(shù)中的參數(shù)是傳遞給誰的,就比如上面的語句執(zhí)行后,name="123",age="123",那哪個才是正確的?這個問題在使用dojo Grid的model里就很麻煩,定義一個model得這樣:new dojox.grid._data.Table(null, 23、null,data);我要是想擴(kuò)展這個Model,更麻煩,所有子類的構(gòu)造函數(shù)都被父類給搞亂了。所以推薦的做法是使用關(guān)聯(lián)數(shù)組作為構(gòu)造函數(shù)的參數(shù),就像Python里的關(guān)鍵字參數(shù)。
constructor:function(args){
??? var args = args || {};
??? this.name = args.name;
??? this.age = args.age;
}
多繼承,mixin
說到繼承,多繼承的問題又來了。dojo支持多繼承,準(zhǔn)確地說,是mixin。還記得dojo.declare的第二個參數(shù)嗎,就是表示父類的那個參數(shù),這個參數(shù)可以是一個數(shù)組,數(shù) 24、組的第一個元素作為聲明的類的父類,其他的作為mixin。子類自動獲得父類和mixin的所有方法,后面的mixin的同名方法覆蓋前面的方法。
dojo.declare("Customer",null,{
??? say:function(){
??????? alert("Hello Customer");
??? },
??? getDiscount:function(){
??????? alert("Discount in Customer");
??? }
});
dojo.declare("MixinClass",null,{
??? say:function(){ 25、
??????? 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"
其他的比較有用的函數(shù)就是dojo.mixin和dojo.extend了,顧名思義,一個是作用于對象實例, 26、一個是用于擴(kuò)展class,翻文檔和源碼吧。
package機(jī)制
說完了dojo里的類繼承機(jī)制,不得不說說package機(jī)制。
主要用到的有
dojo.require
dojo.provide
dojo.registerModulePath
dojo.require
dojo.require就是引入相應(yīng)路徑文件下的js文件,現(xiàn)在已經(jīng)有很多l(xiāng)ibrary這樣做了?,F(xiàn)在我們假設(shè)要用project/dojo-lib/dojo/string.js
dojo中的頂層目錄就是dojo.js所在目錄的上一層,即"project/dojo-lib/",而dojo.js放 27、在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.provide
要自己編寫一個package怎么辦,那就利用dojo.p 28、rovide。比如要寫在:project/dojo-lib/com/javaeye/fyting/Package1.js 那么在對應(yīng)的Package1.js中第一行需要這樣寫:
dojo.provide("com.javaeye.fyting.Package1");
類似java里的package聲明,是吧?
dojo.registerModulePath
那要是我寫的js文件不想和dojo放在一起怎么辦呢,那就用registerModulePath。假設(shè)要放在:
project/js/com/javaeye/fyting/Package2.js
Package2.js和 29、上面的Package1.js一樣的寫法,不需要作特殊變化,就這樣就行:
dojo.provide("com.javaeye.fyting.Package2");
在使用時,需要指名這個Package2.js所在的位置,
dojo.registerModulePath("com","../../js/com");
只需要注意這里的相對路徑是相對dojo.js來的。
我們假設(shè)所有以com.javaeye開頭的js都放在一起,而com.microsoft的放在另外的地方,為了防止沖突,可以這樣:
dojo.registerModulePath("com.javaeye","../../js/com/javaeye");
dojo.registerModulePath("com.microsoft","../../javascript/com/microsoft");
總得來說,package機(jī)制是開發(fā)大型項目必須的,但是造成了調(diào)試?yán)щy,使用dojo.require引入js出錯時,根本不知道是什么原因,所以調(diào)試時最好手動引入js,dojo的test也是這么搞的。還有js框架中的各種實現(xiàn)類繼承的手法,也造成調(diào)試?yán)щy,dojo還隨地拋出個Error,又缺少java那樣的error statck,根本不知道錯誤根源在哪兒。所以,期待js原生地支持這些。
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 沖壓安全培訓(xùn)講義通用PPT課件
- 幼兒園總務(wù)工作管理課件
- 幼兒園團(tuán)隊建設(shè)課件
- 3億以內(nèi)數(shù)的讀法與寫法課件
- 《交通安全伴我成長》【優(yōu)秀課件】
- 臨床試驗中隨機(jī)分組的概述
- 34第八章第四節(jié)澳大利亞
- 臨床藥理學(xué)第5章藥物的臨床研究
- 放線菌屬與諾卡菌屬
- 第一章12121測量距離或高度問題(教育精品)
- 建設(shè)工程投資控制培訓(xùn)課件
- 中考復(fù)習(xí)首字母填空教學(xué)課件
- 第6課二戰(zhàn)的發(fā)(教育精品)
- 思想品德九年級第二單元知識樹(教育精品)
- 竹文化主題樂園城市課件