• <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 閱讀(770) 評論(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);
            久久久精品人妻一区二区三区四 | 亚洲精品NV久久久久久久久久| 日本一区精品久久久久影院| 国产精品美女久久久久AV福利| 久久久久国产一级毛片高清板| 欧美亚洲日本久久精品| 婷婷久久久亚洲欧洲日产国码AV | 99久久精品国产毛片| 欧美久久天天综合香蕉伊| 久久综合给合久久狠狠狠97色| av无码久久久久不卡免费网站| 国产精品美女久久久免费| 97精品伊人久久久大香线蕉| 国产精品青草久久久久福利99 | 久久精品国产久精国产果冻传媒 | 国产日韩欧美久久| 久久综合久久自在自线精品自| 久久久精品国产Sm最大网站| 久久精品国产91久久综合麻豆自制 | 久久婷婷五月综合色高清| 久久久久综合网久久| 久久九色综合九色99伊人| 久久久无码精品亚洲日韩按摩| 欧美一级久久久久久久大| 欧美亚洲另类久久综合| 久久人人妻人人爽人人爽| 久久综合久久综合亚洲| 香蕉99久久国产综合精品宅男自| 久久99国产精品久久99果冻传媒| 中文字幕乱码人妻无码久久| 欧美日韩精品久久免费| 欧美亚洲国产精品久久| 精品久久久久久国产免费了| 91精品观看91久久久久久| 久久久青草青青亚洲国产免观| 国产精品美女久久久久久2018| 久久婷婷五月综合国产尤物app | 91精品国产高清久久久久久国产嫩草| 一本一本久久aa综合精品| 久久久无码精品亚洲日韩蜜臀浪潮 | 欧美日韩精品久久免费|