Javascript 使用function定義建構函式

來源:互聯網
上載者:User

Javascript中建立對象的文法是在new運算子的後面跟著一個函數的調用。如 複製代碼 代碼如下:var obj = new Object();
var date = new Date();

運算子new首先建立一個新的沒有任何屬性的對象,然後調用該函數,把新的對象作為this關鍵字的值傳遞。 複製代碼 代碼如下:var date = new Date()的虛擬碼的實現就是
var obj = {};
var date = Date.call(obj);

建構函式的作用就是初始化一個新建立的對象,並在使用對象前設定對象的屬性。如果定義自己的建構函式,只需要編寫一個為this添加屬性的函數就可以了。下面的代碼定義了一個建構函式: 複製代碼 代碼如下:function Rectangle(w, h)
{
this.width = w;
this.height = h;
}

然後,可以使用new運算子調用這個函數來建立對象的執行個體 複製代碼 代碼如下:var rect = new Rectange(4,8);

建構函式的傳回值
Javascript中的建構函式通常沒有傳回值。但是,函數是允許有傳回值的。如果一個建構函式有一個傳回值,則返回的對象成為new運算式的值。在此情況下,作為this的對象將會被拋棄。

使用建構函式定義法
文法 複製代碼 代碼如下:var object=new objectname();
var -- 聲明物件變數
object -- 對象的名稱
new -- new的關鍵詞(JavaScript關鍵詞)
objectname -- 建構函式名稱

樣本 複製代碼 代碼如下://定義建構函式
function Site(url, name)
{
this.url = "www.jb51.net";
this.name ="夢之都";
}
//使用建構函式產生一個JavaScript對象的執行個體
var mysite = new Site();
alert(mysite.url);

建構函式通常可以初始化對象中的一些內容,JavaScript內部提供的一些對象通常需要使用建構函式的方法產生。JavaScript函數的內容將在下一章介紹。

直接定義法建立JavaScript對象 複製代碼 代碼如下://定義對象文法
var object={};
//對象內的屬性文法(屬性名稱(property)與屬性值(value)是成對出現的)
object.property=value;
//對象內的函數文法(函數名(func)與函數內容是成對出現的)
object.func=function(){...;};

var -- 聲明物件變數
object -- 對象的名稱
property -- 對象的屬性名稱
func -- 對象的方法名
說明:對象可以包含一些屬性(函數可以看作帶有括弧的特殊屬性),每個屬性有名稱和值。名稱可以是任何字串甚至是空。值可以是任何javascript類型,但不能是undefined。

使用定義法定義的對象樣本 複製代碼 代碼如下:var site = {};
site.URL = "www.jb51.net";
site.name = "指令碼之家";
site.englishname = "jb51";
site.author = "指令碼";
site.summary = "免費的網頁設計教程";
site.pagescount = 100;
site.isOK = true;
site.startdate = new Date(2005, 12);
site.say = function(){alert(this.englishname+" say : hello world!")};
site.age = function(){var theage=(new Date().getFullYear())-site.startdate.getFullYear();alert(this.name+"已經"+theage+"歲了!")}

使用建構函式建立JavaScript對象樣本 -- 可以嘗試編輯
使用建構函式建立JavaScript對象
上面的方法定義了一個site的對象,並且為其定義了七個屬性,與兩個個方法。

say方法會列印出jb51 say : hello world!的字串
age方法會計算出夢之都網站的年齡
猴子提示: 注意每個屬性與函數前面都要加上對象的名稱,否則JavaScript無法判斷它是屬於那個對象的。

下面的課程將講解直接定義法的延伸,JSON定義法。 <meta http-equiv="Content-Type" content="text/html; charset=gb2312"><p>建構函式法建立JavaScript對象</p><p> <p>直接法建立JavaScript對象</p><p> <p>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.