亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

javascript 構造函數方式定義對象

2024-05-06 16:13:29
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了javascript 構造函數方式定義對象的方法及示例,需要的朋友可以參考下
 
 

javascript是動態語言,可以在運行時給對象添加屬性,也可以給對象刪除(delete)屬性

 

復制代碼代碼如下:

<html> 
<head>
<script type="text/javascript">
/*
//01.定義對象第一種方式
var object =new Object();
alert(object.username);
//01.1增加屬性username
object["username"]="liujianglong";
//object.username="liujl";
alert(object.username);
//01.2刪除屬性username
delete object.username;//username屬性已經從object對象中刪除
alert(object.username);
*/
//02.定義對象第二種方式--在javascript中定義對象的一種最常見的方式
var object={name:"zhangsan",age:10,sex:"fale"};
alert(object.name);
alert(object.age);
alert(object.sex);
</script>
</head>         
<body>
</body>
</html>

 

屬性名:方法名  也是可以的.因為函數本身就是個對象

javascript 數組排序

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
var array=[1,3,25];
/////////////////////////////////
var compare=function(num1,num2){
    var temp1=parseInt(num1);
    var temp2=parseInt(num2);
    if(temp1<temp2){
        return -1;
    }else if(temp1==temp2){
        return 0;
    }else{
        return 1;
    }
}
//array.sort(compare);//01.函數名是對象引用
////////////////////////////////

 

//02.匿名函數方式//////////////////
array.sort(function c(num1,num2){
var temp1=parseInt(num1);
    var temp2=parseInt(num2);
    if(temp1<temp2){
        return -1;
    }else if(temp1==temp2){
        return 0;
    }else{
        return 1;
    }
});
/////////////////////////////////
alert(array);
</script>
</head>         
<body>
</body>
</html>

 

javascript中定義對象的幾種方式(javascript中沒有類的概念,只有對象 )

第一種方式: 基于已有對象擴充其屬性和方法

 

復制代碼代碼如下:

<script type="text/javascript">
//01.基于已有對象擴充其屬性和方法
var object=new Object();
object.username="zhangsan";
object.sayName=function (name){
    this.username=name;
    alert(this.username);
}
alert(object.username);
object.sayName("lisi");
alert(object.username);
</script>

 

這種方法具有局限性,因為javascript不像java那樣具有類的概念,寫一個類,之后new就可以得到一個具有了這些屬性、方法的對象了。

這時如果要擁有object2就只能把上面來的代碼再寫一份,這是不太好的。

第二種方式: 工廠方式

           類似于java中靜態的工廠方法。

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
//對象工廠方法
var  createObject=function(){
    var object=new Object();
    object.username="zhangsan";
    object.password="123";
    object.get=function(){
        alert(this.username+" , "+object.password); 
    }
    return object;
}
var obj1=createObject();
var obj2=createObject();
obj1.get();
//修改對象2的密碼
obj2["password"]="123456";
obj2.get();
</script>
</head>         
<body>
</body>
</html>

 

上面這種方式創建對象有弊端(每個對象都有一個get方法,從而浪費了內存),改進后的工廠方式( 所有對象共享一個get方法):

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
//所有對象共享的get方法
var get=function(){
    alert(this.username+" , "+this.password);
}
//對象工廠方法
var createObject=function(username,password){
    var object=new Object();
    object.username=username;
    object.password=password;
    object.get=get;//注意:這里不寫方法的括號
    return object;
}
//通過工廠方法創建對象
var object1=createObject("zhangsan","123");
var object2=createObject("lisi","345");
//調用get方法
object1.get();
object2.get();
</script>
</head>         
<body>
</body>
</html>

 

第三種方式: 構造函數方式 定義對象

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
var get=function(){
    alert(this.username+" , "+this.password);
}
function Person(username,password){
    //在執行第一行代碼前,js引擎會為我們生成一個對象
    this.username=username;
    this.password=password;
    this.get=get;
    //在此處,有一個隱藏的return語句,用于返回之前生成的對象[這點是和工廠模式不一樣的地方]
}
var person=new Person("zhangsan","123");
person.get();
</script>
</head>         
<body>
</body>
</html>

 

第四種方式: 原型(Prototype)方式創建對象

prototype是object對象中的屬性,所有person對象也可以擁有prototype這個屬性。

可以給對象的原型增加一些屬性,方法。

單純的使用原型方式創建對象的缺點:①無法傳參數,只能在對象創建后再改變它的值

                                                      ②可能會導致程序錯誤

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
function Person(){
}
Person.prototype.username="zhangsan";
Person.prototype.password="123";
Person.prototype.getInfo=function(){
    alert(this.username+" , "+this.password);
}
var person1=new Person();
var person2=new Person();
person1.username="lisi";
person1.getInfo();
person2.getInfo();
</script>
</head>         
<body>
</body>
</html>

 

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
function Person(){
}
Person.prototype.username=new Array();
Person.prototype.password="123";
Person.prototype.getInfo=function(){
    alert(this.username+" , "+this.password);
}
var person1=new Person();
var person2=new Person();
person1.username.push("wanglaowu");
person1.username.push("wanglaowu2");
person2.password="456";
person1.getInfo    ();
person2.getInfo();
</script>
</head>         
<body>
</body>
</html>

 

單純使用原型方式定義對象無法再構造函數中為屬性賦初值,只能在對象生成后再去改變屬性值。

第五種方式: 使用原型+構造函數方式來定義對象----推薦使用

對象之間的屬性互不干擾
各個對象之間共享同一個方法

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
//使用原型+構造函數方式來定義對象
function Person(){
    //屬性 定義在構造函數中
    this.username=new Array();
    this.password="123";
}
    //方法 定義在原型中
Person.prototype.getInfo=function(){
    alert(this.username+" , "+this.password);
}
var p1=new Person();
var p2=new Person();
p1.username.push("zhangsan");
p2.username.push("lisi");
p1.getInfo();
p2.getInfo();
</script>
</head>         
<body>
</body>
</html>

 

第六種方式: 動態原型方式----推薦使用

         在構造函數中通過標志量讓所有對象共享一個方法,而每個對象擁有自己的屬性。

 

復制代碼代碼如下:

<!DOCTYPE html>
<html> 
<head>
<script type="text/javascript">
var Person=function (username,password){
    this.username=username;
    this.password=password;
    if(typeof Person.flag=="undefined"){
        alert("invoked");
        Person.prototype.getInfo=function(){
            alert(this.username+" , "+this.password);
        }
        Person.flag=true;    
    }
}
var p1=new Person("zhangsan","123");
var p2=new Person("lisi","456");
p1.getInfo();
p2.getInfo();
</script>
</head>         
<body>
</body>
</html>
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产99视频精品免视看7| 国产成人av在线播放| 亚洲成人网久久久| 欧美自拍视频在线| 日韩高清免费观看| 92看片淫黄大片欧美看国产片| 国产成人涩涩涩视频在线观看| 日韩激情在线视频| 欧美日韩国产丝袜美女| 国产精品自产拍在线观看中文| 久久久精品国产一区二区| 久久精品国产亚洲一区二区| 久久久久久999| 久久久亚洲天堂| 欧美精品九九久久| 国产精品第一区| 8x拔播拔播x8国产精品| 欧美日韩一区二区免费在线观看| 欧美视频在线免费| 国产精品扒开腿爽爽爽视频| 欧美激情videoshd| 欧美在线亚洲在线| 欧美大成色www永久网站婷| 北条麻妃一区二区在线观看| 欧洲午夜精品久久久| 18久久久久久| 国产午夜一区二区| 成人网欧美在线视频| 亚洲一级免费视频| 亚洲精品久久7777777| 欧日韩不卡在线视频| 国产一区二区精品丝袜| 黄色精品在线看| 亚洲精品美女久久久| 国产精品国产自产拍高清av水多| 欧美视频在线免费| 久久久久久久久久久亚洲| 91日本在线视频| 91精品久久久久久综合乱菊| 国产午夜精品免费一区二区三区| 成人日韩在线电影| 亚洲视频网站在线观看| 久久久国产一区二区| 中文字幕久精品免费视频| 97人人做人人爱| 日韩电视剧在线观看免费网站| 欧美激情亚洲自拍| 欧洲一区二区视频| 综合网日日天干夜夜久久| 亲爱的老师9免费观看全集电视剧| 国产91色在线免费| 国产精品尤物福利片在线观看| 国产一区二区在线免费| 国产精品video| 国产精品入口夜色视频大尺度| 一区二区三区美女xx视频| 国产精品色婷婷视频| 欧美午夜激情视频| 亚洲欧美一区二区三区在线| 中文字幕日韩欧美在线视频| 日韩国产欧美精品一区二区三区| 亚洲自拍偷拍第一页| 日韩欧美在线看| 国产精品视频一区二区高潮| 国产精品自产拍在线观看| 国产精品女视频| 色婷婷av一区二区三区久久| 97在线视频观看| 国产这里只有精品| 91精品国产综合久久香蕉的用户体验| 亚洲欧美日韩国产成人| 亚洲欧美国产va在线影院| 北条麻妃一区二区三区中文字幕| 亚洲午夜小视频| 欧美视频裸体精品| 欧美精品18videosex性欧美| 亚洲免费一在线| 亚洲国产91精品在线观看| 国外日韩电影在线观看| 久久成人免费视频| 欧美激情免费看| 色综合天天综合网国产成人网| 亚洲美女av网站| 欧洲美女7788成人免费视频| 北条麻妃一区二区在线观看| 国产精品久久久久久五月尺| 成人午夜在线观看| 国产精品一区二区三区在线播放| 97**国产露脸精品国产| 欧美成人免费一级人片100| 久久综合五月天| 久久人人爽国产| 国产精品天天狠天天看| 国产亚洲精品激情久久| 亚洲一区av在线播放| 57pao国产精品一区| 精品国产乱码久久久久久天美| 91久久国产婷婷一区二区| 亚洲精品成人av| 福利视频一区二区| 亚洲黄色av女优在线观看| 亚洲天堂男人天堂女人天堂| 欧美日韩在线免费观看| 国产精品久久久久久亚洲调教| 日韩av不卡在线| 欧美大尺度电影在线观看| 国产精品久久久久久亚洲影视| 热草久综合在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品自拍偷拍视频| 日韩久久免费电影| 国产精品6699| 欧美交受高潮1| 欧美人在线观看| 欧美与欧洲交xxxx免费观看| 国产69久久精品成人看| 国产免费一区视频观看免费| 久久综合九色九九| 精品国偷自产在线视频99| 国产999视频| 色偷偷综合社区| 精品毛片网大全| 中文一区二区视频| 日本成人黄色片| 欧美尺度大的性做爰视频| 伦伦影院午夜日韩欧美限制| 国产精品v日韩精品| 亚洲国语精品自产拍在线观看| 久久久精品国产| 日本不卡免费高清视频| 亚洲综合日韩中文字幕v在线| 琪琪第一精品导航| 国产成人福利视频| 中文字幕日韩电影| 国产精品久久一区| 91人成网站www| 欧美福利小视频| 亚洲色图日韩av| 亚洲国产精品久久久久秋霞不卡| 美女精品视频一区| 日韩在线www| 亚洲奶大毛多的老太婆| 中文字幕少妇一区二区三区| 久99九色视频在线观看| 久久精品国产精品亚洲| 国产精品一区久久久| 海角国产乱辈乱精品视频| 日韩不卡在线观看| 在线免费观看羞羞视频一区二区| 欧美精品在线免费| 亚洲国产免费av| 精品久久久久久久久久| 欧美精品在线观看91| 国产精品久久久久久av下载红粉| 神马国产精品影院av| 亚洲第一男人天堂| 欧美国产日本高清在线| 久久久欧美精品| 黑人精品xxx一区一二区| 日韩电影免费观看在线观看| 38少妇精品导航| 成人免费直播live| 日本精品一区二区三区在线播放视频| 久久精品国产欧美亚洲人人爽|