zoukankan      html  css  js  c++  java
  • js自定义对象

    注意:对于已经实例化的对象,我们可以动态增加和删除它的属性与方法,语法如下(假定对象实例为obj):
    动态增加对象属性 obj.newPropertyName=value; 动态增加对象方法 obj.newMethodName=method或者=function(arg1,…,argN){} 动态删除对象属性 delete obj.propertyName 动态删除对象方法 delete obj.methodName 2)例子: function User(name){ this.name=name; this.age=18; } var user=new User(“user1”); user.sister=“susan”; alert(user.sister);//运行通过 delete user.sister; alert(user.sister);//报错:对象不支持该属性 user.getMotherName=function(){return “mary”;} alert(user.getMotherName());//运行通过 delete user.getMotherName; alert(user.getMotherName());//报错:对象不支持该方法

    一,基本概念

    1,自定义对象。
    根据JS的对象扩展机制,用户可以自定义JS对象,这与Java语言有类似的地方。
    与自定义对象相对应的是JS标准对象,例如Date、Array、Math等等。


    2,原型(prototype)
    在JS中,这是一种创建对象属性和方法的方式,通过prototype可以为对象添加新的属性和方法。
    通过prototype我们可以为JS标准对象添加新的属性和方法,例如对于String对象,我们可以为其添加一个新的方法trim()。
    与严格的编程语言(例如Java)不同,我们可以在运行期间为JS对象动态添加新的属性。

    二、对象创建方式

    1、对象初始化器方式

    格式:objectName = {property1:value1, property2:value2,…, propertyN:valueN}

    注意:value则是对象的值,值可以是字符串、数字或对象三者之一
    例如: var user={name:“user1”,age:18};
          var user={name:“user1”,job:{salary:3000,title:programmer}
    以这种方式也可以初始化对象的方法,例如:
        var user={name:“user1”,age:18,getName:function(){
                    return this.name;
              }         
        }
    后面将以构造函数方式为重点进行讲解,包括属性和方法的定义等等,也针对构造函数的方式进行讲解。
    

     2、构造函数方式

    格式如下:function User(name,age){
              this.name=name;
              this.age=age;
              this.canFly=false;
        }
        var use=new User();

    三、定义对象属性

    JS中可以为对象定义三种类型的属性:私有属性、实例属性和类属性

    1、私有属性定义:

    注意:私有属性只能在构造函数内部定义与使用。(故如果想创建私有属性,就用构造函数方式创建对象)
    语法格式:var propertyName=value;
    例如:
    function User(age){
               this.age=age;
               var isChild=age<12;
               this.isLittleChild=isChild;
        }
        var user=new User(15);
        alert(user.isLittleChild);//正确的方式
        alert(user.isChild);//报错:对象不支持此属性或方法
    

     2、实例属性定义,也存在两种方式:

    prototype方式:
    语法格式:functionName.prototype.propertyName=value
    
    this方式:
    语法格式:this.propertyName=value,注意后面例子中this使用的位置
    

    例如:
    function User(){ }
    User.prototype.name=“user1”;
    User.prototype.age=18;
    var user=new User();
    alert(user.age);
    —————————————–
    function User(name,age,job){
             this.name=“user1”;
             this.age=18;
             this.job=job;
        }
        alert(user.age);

    3、类属性定义

    语法格式:functionName.propertyName=value
    例如: function User(){ } User.MAX_AGE=200; User.MIN_AGE=0; alert(User.MAX_AGE); 参考JS标准对象的类属性: Number.MAX_VALUE //最大数值 Math.PI //圆周率

    注意:

    对于属性的定义,除了上面较为正规的方式外,还有一种非常特别的定义方式,语法格式: obj[index]=value

    例子:
         function User(name){
                 this.name=name;
                 this.age=18;
                 this[1]=“ok”;
                 this[200]=“year”;
         }
         var user=new User(“user1”);
         alert(user[1]);
         在上面例子中,要注意:不同通过this[1]来获取age属性,也不能通过this[0]来获取name属性,即通过index方式定义的必须使用index方式来引用,而没有通过index方式定义的,必须以正常方式引用
    

    四、定义对象方法

    JS中可以为对象定义三种类型的方法:私有方法、实例方法和类方法,

    1、私有方法:

    注意:私有方法只能在构造函数内部定义与使用。(故如果想创建私有方法,就用构造函数方式创建对象)
    语法格式:function methodName(arg1,…,argN){ }
    例如:
    function User(name){
              this.name=name;
              function getNameLength(nameStr){
                  return nameStr.length;
              }
              this.nameLength=getNameLength(this.name);   
        }

     2、定义实例方法,也存在两种方式:

    prototype方式:
    语法格式:
    functionName.prototype.methodName=method;
    或者
    functionName.prototype.methodName=function(arg1,…,argN){}; this方式: 语法格式:
    this.methodName=method;
    或者
    this.methodName=function(arg1,…,argN){};

    例如:
    function User(name){
           this.name=name;
    }
    User.prototype.getName=function(){
           return this.name;
    };
    User.prototype.setName=function(newName){
           this.name=newName;
    };

    3、类方法定义

    类方法需要在构造函数外面定义,可以直接通过构造函数名对其进行引用。

    语法格式:functionName.methodName=method;
    例如: function User(name){
                this.name=name;
        }
        User.getMaxAge=getUserMaxAge;
        function getUserMaxAge(){
               return 200;
        }
        或者
        User.getMaxAge=function(){return 200;};
        alert(User.getMaxAge());

     五、属性和方法的动态增加

    六、属性与方法的引用

    1)从可见性上说:
    私有属性与方法,只能在对象内部引用。
    实例属性与方法,可以在任何地方使用,但必须通过对象来引用。
    类属性与方法,可以在任何地方使用,但不能通过对象的实例来引用(这与Java不同,在Java中静态成员可以通过实例来访问)。

    2)从对象层次上说:
    与Java bean的引用类似,可以进行深层次的引用。
    几种方式:
    简单属性:obj.propertyName
    对象属性:obj.innerObj.propertyName
    索引属性:obj.propertyName[index]

    3)从定义方式上说:
    通过index方式定义的属性,必须通过index方式才能引用。
    通过非index方式定义的属性,必须通过正常的方式才能引用。
    另外注意:对象的方法不能通过index方式来定义。
  • 相关阅读:
    Could A New Linux Base For Tablets/Smartphones Succeed In 2017?
    使用libhybris,glibc和bionic共存时的TLS冲突的问题
    6 Open Source Mobile OS Alternatives To Android in 2018
    Using MultiROM
    GPU drivers are written by the GPU IP vendors and they only provide Android drivers
    Jolla Brings Wayland Atop Android GPU Drivers
    How to Use Libhybris and Android GPU Libraries with Mer (Linux) on the Cubieboard
    闲聊Libhybris
    【ARM-Linux开发】wayland和weston的介绍
    Wayland and X.org problem : Why not following the Android Solution ?
  • 原文地址:https://www.cnblogs.com/Alight/p/3101729.html
Copyright © 2011-2022 走看看