一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Javascript 使用function定義構(gòu)造函數(shù)

Javascript中創(chuàng)建對象的語法是在new運算符的后面跟著一個函數(shù)的調(diào)用。如
復制代碼 代碼如下:
var obj = new Object();
var date = new Date();

運算符new首先創(chuàng)建一個新的沒有任何屬性的對象,然后調(diào)用該函數(shù),把新的對象作為this關(guān)鍵字的值傳遞。
復制代碼 代碼如下:
var date = new Date()的偽代碼的實現(xiàn)就是
var obj = {};
var date = Date.call(obj);

構(gòu)造函數(shù)的作用就是初始化一個新創(chuàng)建的對象,并在使用對象前設(shè)置對象的屬性。如果定義自己的構(gòu)造函數(shù),只需要編寫一個為this添加屬性的函數(shù)就可以了。下面的代碼定義了一個構(gòu)造函數(shù):
復制代碼 代碼如下:
function Rectangle(w, h)
{
this.width = w;
this.height = h;
}

然后,可以使用new運算符調(diào)用這個函數(shù)來創(chuàng)建對象的實例
復制代碼 代碼如下:
var rect = new Rectange(4,8);

構(gòu)造函數(shù)的返回值
Javascript中的構(gòu)造函數(shù)通常沒有返回值。但是,函數(shù)是允許有返回值的。如果一個構(gòu)造函數(shù)有一個返回值,則返回的對象成為new表達式的值。在此情況下,作為this的對象將會被拋棄。

使用構(gòu)造函數(shù)定義法
語法
復制代碼 代碼如下:
var object=new objectname();
var -- 聲明對象變量
object -- 對象的名稱
new -- new的關(guān)鍵詞(JavaScript關(guān)鍵詞)
objectname -- 構(gòu)造函數(shù)名稱

示例
復制代碼 代碼如下:
//定義構(gòu)造函數(shù)
function Site(url, name)
{
this.url = "www.jb51.NET";
this.name ="夢之都";
}
//使用構(gòu)造函數(shù)產(chǎn)生一個JavaScript對象的實例
var mysite = new Site();
alert(mysite.url);

構(gòu)造函數(shù)通常可以初始化對象中的一些內(nèi)容,JavaScript內(nèi)部提供的一些對象通常需要使用構(gòu)造函數(shù)的方法生成。JavaScript函數(shù)的內(nèi)容將在下一章介紹。

直接定義法創(chuàng)建JavaScript對象
復制代碼 代碼如下:
//定義對象語法
var object={};
//對象內(nèi)的屬性語法(屬性名(property)與屬性值(value)是成對出現(xiàn)的)
object.property=value;
//對象內(nèi)的函數(shù)語法(函數(shù)名(func)與函數(shù)內(nèi)容是成對出現(xiàn)的)
object.func=function(){...;};

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

使用定義法定義的對象示例
復制代碼 代碼如下:
var site = {};
site.URL = "www.jb51.NET";
site.name = "腳本之家";
site.englishname = "jb51";
site.author = "腳本";
site.summary = "免費的網(wǎng)頁設(shè)計教程";
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+"已經(jīng)"+theage+"歲了!")}

使用構(gòu)造函數(shù)創(chuàng)建JavaScript對象示例 -- 可以嘗試編輯
使用構(gòu)造函數(shù)創(chuàng)建JavaScript對象
上面的方法定義了一個site的對象,并且為其定義了七個屬性,與兩個個方法。

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

下面的課程將講解直接定義法的延伸,JSON定義法。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

JavaScript技術(shù)Javascript 使用function定義構(gòu)造函數(shù),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美经典成人在观看线视频 | 欧美成人全部费免网站 | 亚洲一区二区三区成人 | 欧美日韩国产一区二区三区在线观看 | 91成人在线免费视频 | 人人添人人澡人人澡人人人人 | 91精品国产91热久久久久福利 | 亚洲国产精品婷婷久久 | 成人免费福利视频 | 五月天综合激情网 | 黄网站视频观看免费 | 日本一区二区三区在线 视频观看免费 | 欧美人与禽zoz0性伦交 | 国产人成激情视频在线观看 | 中文字幕色综合久久 | 免费观看黄色视屏 | 欧美一级艳片爽快片 | 亚洲欧美综合图片 | 婷婷色影院 | 岛国美女全棵写真视频在线观看 | 色综合手机在线 | 2020国产精品视频免费 | 精品成人 | 国产91在线视频观看 | 男人女人无遮掩免费视频 | 国产激情小说 | 国产精品久久久久久福利69堂 | 亚洲精品影院久久久久久 | 国产91成人精品亚洲精品 | 免费国产在线观看 | 美女色黄| 成人在线观看一区 | 成人黄网大全在线观看 | 欧美福利视频网站 | 亚洲精品亚洲人成在线播放 | 91操碰| 七七七久久久久人综合 | 欧美人体大胆艺术 | 国产精品一区二区三区四区五区 | 欧美日韩一区二区三区久久 | 黄色片网站在线免费观看 |