日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Dojo 之 面向对象

發(fā)布時(shí)間:2024/9/20 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Dojo 之 面向对象 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

面向?qū)ο?/strong>三大特性:封裝、繼承、多態(tài)。在熟悉了Java/C#/C++這些高級(jí)面向?qū)ο笳Z言的語法結(jié)構(gòu)后,我們或多或少會(huì)對(duì)javascript腳本語言的面向?qū)ο蟾械揭恍┎贿m,function、prototype、call、apply……

為了消除這種對(duì)javascript面向?qū)ο笳Z法的不適,眾多js庫都構(gòu)建了更符合傳統(tǒng)OO編程思想的代碼框架,如prototype、mootools等等,引用mootools文檔中創(chuàng)建對(duì)象的例子

var?Animal?=?new?Class({
  initialize:?function(age){
  this.age?=?age;
  }
  });
  var?Cat?=?Animal.extend({
  initialize:?function(name,?age){
  this.parent(age);?//將調(diào)用Animal的initialize方法;
  this.name?=?name;
  }
  });
  var?myCat?=?new?Cat('Micia',?20);
  alert(myCat.name);?//顯示?'Micia'
  alert(myCat.age);?//顯示?20

Dojo作為一個(gè)強(qiáng)大的javascript工具箱,有它自己面向?qū)ο蟮拈_發(fā)方式,用declare解決了對(duì)象的創(chuàng)建和繼承的問題,文檔中的例子:

dojo.declare("my.classes.bar",?my.classes.foo,?{
  //?properties?to?be?added?to?the?class?prototype
  someValue:?2,
  //?initialization?function
  constructor:?function(){
  this.myComplicatedObject?=?new?ReallyComplicatedObject();
  },
  //?other?functions
  someMethod:?function(){
  doStuff();
  }
  );

declare的第一個(gè)參數(shù)是對(duì)象名稱,最后一個(gè)參數(shù)指定在這個(gè)對(duì)象里要添加的內(nèi)容,包括函數(shù)和屬性,寫個(gè)例子

dojo.declare("Apple",?null,?{
  price:?5,
  constructor:?function(weight)?{
  this.total?=?weight?*?this.price;
  },
  print:?function()?{
  alert("The?total?price?is?"?+?this.total);
  }
  }
  );
  var?myapple?=?new?Apple(10);
  myapple.print();?//輸出結(jié)果:"The?total?price?is?50"

上例通過declare創(chuàng)建了一個(gè)Apple對(duì)象,javascript本身沒有類的概念,可以使用對(duì)象本身來創(chuàng)建新的對(duì)象myapple,通過構(gòu)造函數(shù)的參數(shù)值計(jì)算蘋果的總價(jià),print函數(shù)輸出結(jié)果,非常形象的構(gòu)建了一個(gè)Apple“類”,非常容易理解。要注意的是,這里如果聲明默認(rèn)構(gòu)造函數(shù),"new Apple(10)"將直接執(zhí)行默認(rèn)構(gòu)造函數(shù),帶參數(shù)的構(gòu)造函數(shù)就被忽略了,并非C++中順序執(zhí)行。

注意dojo.declare第二個(gè)參數(shù),如果創(chuàng)建一個(gè)獨(dú)立的新對(duì)象,可以設(shè)為null,當(dāng)需要從其他一個(gè)或多個(gè)對(duì)象繼承時(shí),則為對(duì)象名稱,這樣就方便的實(shí)現(xiàn)了對(duì)象繼承。多個(gè)對(duì)象繼承,declare第二個(gè)參數(shù)為一數(shù)組,第一個(gè)元素為原型父對(duì)象,其他的為mixin對(duì)象,通過代碼來理解。

創(chuàng)建一個(gè)GreenApple對(duì)象,測試alert執(zhí)行順序!mixin對(duì)象的方法將覆蓋之前對(duì)象中的同名函數(shù),除非子對(duì)象也聲明了同名函數(shù)print。

?//輸出
  //"The?height?of?the?tree?is?undefined"
  //"Getting?a?green?apple"
  var?gapple?=?new?GreenApple();
  //輸出,覆蓋了Apple對(duì)象的print
  //"This?is?an?apple?tree"
  gapple.print();
  //"This?is?a?mixin?class"
  gapple.additional();
  dojo/_base/_loader/bootstrap.js有專門的mixin函數(shù),用于對(duì)象的拷貝,將一個(gè)創(chuàng)建好的對(duì)象拷貝到新的對(duì)象中?var?copy?=?dojo.mixin({},?new?Apple(2));
  copy.print();

print輸出結(jié)果是"The total price is 10",mixin參數(shù)一定是創(chuàng)建好的對(duì)象實(shí)例,否則出錯(cuò)!dojo.extend則可以將一個(gè)或多個(gè)對(duì)象的屬性、方法拷貝到一個(gè)原型上,通過prototype實(shí)現(xiàn)繼承,這是繼承的另外一種方式。

通過declare、mixin、extend,dojo給我們提供了一種方便的對(duì)象創(chuàng)建與擴(kuò)展機(jī)制,一般情況下夠用了,感覺還是比較方便,使用時(shí)也存在一些限制,翻翻源代碼就能理解。這里主要是要知道dojo是如何面向?qū)ο蟮?#xff0c;方便我們更好的理解dojo基礎(chǔ)功能,及dijit和 dojox,dojo最為強(qiáng)大還是它的widgets。本文涉及的js源碼:

mixin:dojo/_base/_loader/bootstrap.js

extend:dojo/_base/lang.js

declare:dojo/_base/declare.js

總結(jié)

以上是生活随笔為你收集整理的Dojo 之 面向对象的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。