• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Shuffy

            不斷的學習,不斷的思考,才能不斷的進步.Let's do better together!
            posts - 102, comments - 43, trackbacks - 0, articles - 19

            JS定義(構造)類的方法

            Posted on 2012-04-27 20:58 Shuffy 閱讀(760) 評論(0)  編輯 收藏 引用 所屬分類: Web開發技術
                            //1、構造函數+原型方法
                            //構造函數
                            //等價于Person=function(){}
                            function Person(name,age){
                                
            this.name=name;
                                
            this.age=age;
                            }

                            
            //原型構造(大括號的形式)
                            Person.prototype={
                                gender:
            "",
                                toString:
            function(){
                                    alert(
            "name:"+this.name+",age:"+this.age);
                                }

                            }
            ;
                            
            //原型構造
                            Person.prototype.height=1.5;
                            Person.prototype.toString
            =function(){
                                alert(
            "name:"+this.name+",age:"+this.age+",gender:"+this.gender+",height:"+this.height);
                            }
            ;
                            
            var person=new Person("sandy",25);
                            person.gender
            ="";
                            person.height
            =1.7;
                            alert(person.name);
                            alert(person.age);
                            alert(person.gender);
                            alert(person.height);
                            person.toString();
                            
                            
            //2、原型構造
                            User=function(){};
                            User.prototype
            ={
                                name:
            "",
                                password:
            "",
                                toString:
            function(){
                                    alert(
            this.name+","+this.password);
                                }

                            }
            ;
                            
            var user = new User();
                            user.name
            ="admin";
                            user.password
            ="admin";
                            user.toString();
                            
                            
            //通過原型和this關鍵字構造的屬性和方法是公有的。
                            //原型構造的缺點是當屬性是對象類型時,該屬性為引用類型,多個實例共享這一個屬性,
                            //其中一個實例改變了該屬性之后,所有實例的該屬性都被改變了。
                            
                            
            //3、構造函數方法,可以通過下面類似OOP方式定義類
                            //等價于function Car(sign,number){}
                            Car=function(sign,number){
                                
            //函數里的局部變量,用OOP的觀點看,是私有屬性。
                                var _sign=sign;
                                
            var _number=number;
                                
                                
            this.getSign=function(){
                                    
            return _sign;
                                }
            ;
                                
            this.setSign=function(sign){
                                    _sign
            =sign;
                                }
            ;
                                
            this.getNumber=function(){
                                    
            return _number;
                                }
            ;
                                
            this.setNumber=function(number){
                                    _number
            =number;
                                }
            ;
                            }
            ;
                            
            var car1 = new Car("寶馬","1111111");
                            
            var car2 = new Car("歐迪","2333333");
                            alert(car1.getSign()
            +":"+car1.getNumber());
                            alert(car2.getSign()
            +":"+car2.getNumber());
                            car1.setNumber(
            "23223333");
                            car2.setNumber(
            "444444444");
                            alert(car1.getSign()
            +":"+car1.getNumber());
                            alert(car2.getSign()
            +":"+car2.getNumber());
                            
                            
            //4、工廠方式
                            //工廠方式1
                            //function Song(){}
                            Song=function(){
                                
            //構造一個對象并返回(直接量方式構造一個對象)
                                var obj=new Object();
                                obj.author
            ="";
                                obj.name
            ="";
                                obj.play
            =function(){
                                    alert(
            "author:"+obj.author+",name:"+obj.name);
                                }
            ;
                                
            return obj;
                            }
            ;
                            
            var song=Song();
                            song.author
            ="Jay";
                            song.name
            ="夜曲";
                            song.play();
                            
            //工廠方式2
                            function Music(){
                                
            //新建一個匿名類的對象并返回
                                //var obj = new (function(){
                                //    this.type="";
                                //    this.year="";
                                //})();
                                //return obj;
                                return new (function(){
                                    
            this.type="";
                                    
            this.year="";
                                }
            )();
                            }

                            
            var m = Music();
                            m.type
            ="爵士";
                            m.year
            ="80年代";
                            alert(m.type);
                            alert(m.year);
                            
            //5、定義靜態方法和屬性,只能通過類名訪問,類實例是訪問不到的。
                            Pen=function(){};
                            Pen.DEFAULTCOLOR
            ="BLACK";
                            
            var pen = new Pen();
                            
            //alert(pen.DEFAULTCOLOR);
                            alert(Pen.DEFAULTCOLOR);
            国内精品伊人久久久久AV影院| 久久久无码精品亚洲日韩软件| 久久精品国产欧美日韩| 精品久久无码中文字幕| 久久久婷婷五月亚洲97号色| 久久狠狠爱亚洲综合影院| 伊人久久大香线蕉AV色婷婷色| 久久人人爽人人爽人人片AV高清| 久久频这里精品99香蕉久| 久久精品aⅴ无码中文字字幕不卡| 日韩欧美亚洲综合久久| 亚洲狠狠婷婷综合久久蜜芽| 久久久久久久久无码精品亚洲日韩 | 色诱久久久久综合网ywww| 久久久久精品国产亚洲AV无码| 性高湖久久久久久久久| 人妻精品久久无码区| 久久福利青草精品资源站免费| 国产精品免费久久久久影院| 色综合久久中文字幕综合网| 一个色综合久久| 色综合久久久久综合体桃花网 | 亚洲国产精品人久久| 久久久久一本毛久久久| 亚洲精品乱码久久久久久中文字幕| 蜜臀av性久久久久蜜臀aⅴ| 中文精品久久久久国产网址| 波多野结衣久久精品| 久久国产精品无码HDAV| 性做久久久久久久久| 国产午夜福利精品久久2021| 国产亚洲美女精品久久久| 久久综合亚洲鲁鲁五月天| 国内精品久久久久影院免费| 综合久久给合久久狠狠狠97色| 狠狠狠色丁香婷婷综合久久五月 | 国产精品亚洲综合专区片高清久久久| 模特私拍国产精品久久| 办公室久久精品| 久久精品毛片免费观看| 色狠狠久久综合网|