JavaScript中的對象化編程

關於對象化編程的語句 現在我們有實力學習以下關於對象化編程,但其實屬於上一章的內容瞭。


with 語句 為一個或一組語句指定默認對象。


用法:
with (<對象>) <語句>;
with 語句通常用來縮短特定情形下必須寫的代碼量。在下面的例子中,請註意 Math 的重復使用:
x = Math.cos(3 * Math.PI) + Math.sin(Math.LN10);
y = Math.tan(14 * Math.E);
當使用 with 語句時,代碼變得更短且更易讀:
with (Math) {
  x = cos(3 * PI) + sin(LN10);
  y = tan(14 * E);
}
this 對象 返回“當前”對象。在不同的地方,this 代表不同的對象。如果在 JavaScript 的“主程序”中(不在任何 function 中,不在任何事件處理程序中)使用 this,它就代表 window 對象;如果在 with 語句塊中使用 this,它就代表 with 所指定的對象;如果在事件處理程序中使用 this,它就代表發生事件的對象。


一個常用的 this 用法:
<script>

function check(formObj) {
  …
}

</script>


<body …>

<form …>

<input type=”text” … onchange=”check(this.form)”>

</form>

</body>
這個用法常用於立刻檢測表單輸入的有效性。


自定義構造函數 我們已經知道,Array(),Image()等構造函數能讓我們構造一個變量。其實我們自己也可以寫自己的構造函數。自定義構造函數也是用 function。在 function 裡邊用 this 來定義屬性。
function <構造函數名> [(<參數>)] {
  …
  this.<屬性名> = <初始值>;
  …
}
然後,用 new 構造函數關鍵字來構造變量:
var <變量名> = new <構造函數名>[(<參數>)];
構造變量以後,<變量名>成為一個對象,它有它自己的屬性——用 this 在 function 裡設定的屬性。


以下是一個從網上找到的搜集瀏覽器詳細資料的自定義構造函數的例子:
function Is() {
  var agent = navigator.userAgent.toLowerCase();
  this.major = parseInt(navigator.appVersion);  //主版本號
  this.minor = parseFloat(navigator.appVersion);//全版本號
  this.ns = ((agent.indexOf(mozilla)!=-1) &&
             ((agent.indexOf(spoofer)==-1) && //是否 Netscape
              (agent.indexOf(compatible) == -1)));
  this.ns2 = (this.ns && (this.major == 3));    //是否 Netscape 2
  this.ns3 = (this.ns && (this.major == 3));    //是否 Netscape 3
  this.ns4b = (this.ns && (this.minor < 4.04)); //是否 Netscape 4 低版本
  this.ns4 = (this.ns && (this.major >= 4));    //是否 Netscape 4 高版本
  this.ie = (agent.indexOf(“msie”) != -1);      //是否 IE
  this.ie3 = (this.ie && (this.major == 2));    //是否 IE 3
  this.ie4 = (this.ie && (this.major >= 4));    //是否 IE 4
  this.op3 = (agent.indexOf(“opera”) != -1);    //是否 Opera 3
  this.win = (agent.indexOf(“win”)!=-1);        //是否 Windows 版本
  this.mac = (agent.indexOf(“mac”)!=-1);        //是否 Macintosh 版本
  this.unix = (agent.indexOf(“x11”)!=-1);       //是否 Unix 版本
}


var is = new Is();
這個構造函數非常完整的搜集瞭瀏覽器的信息。我們看到它為對象定義瞭很多個屬性:major, minor, ns, ie, win, mac 等等。它們的意思見上面的註釋。把 is 變量定義為 Is() 對象後,用 if (is.ns) 這種格式就可以很方便的知道瀏覽器的信息瞭。我們也可以從這個構造函數中看到,它也可以使用一般的 JavaScript 語句(上例中為 var 語句)。


讓我們再來看一個使用參數的構造函數:
function myFriend(theName, gender, theAge, birthOn, theJob) {
  this.name = theName;
  this.isMale = (gender.toLowerCase == male);
  this.age = theAge;
  this.birthday = new Date(birthOn);
  this.job = theJob
}


var Stephen = new myFriend(Stephen, Male, 18, Dec 22, 1982, Student);
從這個構造函數我們不但看到瞭參數的用法,還看到瞭不同的屬性用不同的數據型是可以的(上例五個屬性分別為:字符串,佈爾值,數字,日期,字符串),還看到瞭構造函數裡也可以用構造函數來“構造”屬性。如果用瞭足夠的“保護措施”來避免無限循環,更可以用構造函數自身來構造自己的屬性。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *