成员属性、静态属性、私有属性、原型属性

一、成员属性和成员方法
     在构造函数中,通过this.属性声明,或者实例化出对象后,通过“对象.属性”追加的,都属于成员属性或成员方法,也叫实例属性与实例方法;
     成员属性/方法,是属于实例化的这个对象,通过“对象.属性”调用;

function Person(name) {
      this.name = name; // 声明成员属性
      this.say = function() { // 声明成员方法
        console.log('haha')
      }
    }
    var chaiting=new Person('chaiting');
    chaiting.age=18; // 追加成员属性
    console.log(chaiting.name); // chaiting
    console.log(chaiting.age); // 18
    chaiting.say(); // haha

二、静态属性和静态方法
     通过“类名.属性名”,“类名.方法名”声明的变量,成为静态属性、静态方法,也叫类属性、类方法;类属性、类方法是属于类的(构造函数的),这类属性或方法必须通过“类名.属性”调用,而不能通过对象名调用;

function Person(){}
    Person.age = 21;
    Person.say = function(){
      alert('haha');
    }
    console.log(Person.age,111); // 21 111
    Person.say(); // haha
    var chaiting = new Person();
    console.log(chaiting.age,222); // undefined 222
    chaiting.say(); // chaiting.say is not a function

三、私有属性和私有方法
     在构造函数中,通过var声明的属性,成为私有属性,私有属性的作用域仅在当前函数有效,对外不公开,即通过对象/类都无法调用到;

function Person(){
      var sex = 'male';
      console.log(sex); // male 私有属性只能在类内使用
    }
    console.log(Person.sex); // undefined 无法调用,私有属性只能在类内使用,且js变量具有函数作用域
    var chaiting=new Person();
    console.log(chaiting.sex); // undefined 无法调用,私有属性只能在类内使用

四、原型属性和原型方法
     写在了构造函数的prototype上,当使用构造函数实例化对象时,该属性方法会进入新对象的proto上;

function Person(){}
    Person.prototype.name="chaiting"; // 声明原型属性
    Person.prototype.say=function(){ // 声明原型方法
      console.log('haha');
    }
    var person = new Person();
    console.log(person.name); // chaiting 使用对象调用原型属性
    person.say(); // haha 使用对象调用原型方法

     成员属性和原型属性的区别:成员属性是直接声明在对象自身上的,而原型属性是声明在对象的__proto__上,在我们使用“对象名.属性名”访问一个属性时,会先访问成员属性,如果成员属性中找不到,JS会沿着对象的原型链,继续通过__proto__向上查找,也就找到了原型属性,这就是我们可以使用“对象名.属性名”访问成员属性和原型属性的原因;

function Person(name) {
      this.name = name; // 声明成员属性
      this.say = function() { // 声明成员方法
        console.log('haha')
      }
    }
    Person.prototype.sex='female';
    var person=new Person('chaiting');
    person.age=18; // 追加成员属性
    console.log(person)

成员属性和原型属性的区别

五、原型与原型链

  • prototype和__proto__
       ① prototype(函数的原型对象):函数才有prototype,而且所有函数必有prototype,prototype是一个对象,指向当前构造函数的引用地址;
       ② __proto__(对象的原型):对象才有__proto__,而且所有对象必有__proto__(这里的对象除了我们理解的狭义对象,也包括了函数、数组等对象),当用构造函数实例化(new)一个对象时,会将新对象的__proto__属性指向构造函数的prototype;
function Person(){}
var zhangsan = new Person();
console.log(zhangsan.__proto__ == Person.prototype); // true
//【解释】上例中,我们使用函数Person,new出了一个对象zhangsan。 那么对象zhangsan的__proto__就等于函数Person的prototype。

  • 原型链
         从上面的介绍中我们得知:对象的__proto__指向函数的prototype,函数的prototype本身也是个对象,是对象肯定也有__proto__,那他的__proto__指向了谁呢,顺着这个问题,我们延着一个对象__proto__向上查找,这条线路就是我们所说的原型链;
    ①通过构造函数,new出的对象,新对象的__proto__指向构造函数的prototype;
    ②所有函数的__proto__指向Function()的prototype;
    ③非构造函数new出的对象({} new Object() 对象的prototype)的__proto__指向Object的prototype;
    ④ Object的prototype的__proto__指向null;
    原型链

    六、成员属性与原型方法
         习惯上,我们会将属性写为成员属性,而方法写为原型方法,原因如下:
    ①实例化出对象后,所有属性直接在对象上,所有方法都在__proto__上,非常直观清晰;
    ②方法写到prototype上,要更加节省内存;
    ③使用for in循环时,会将对象以及对象原型链上的所有属性和方法打印出来,而方法往往是不需要展示的,将方法写到__proto__上,可以使用hasOwnProperty将原型上的方法过滤掉,不显示;
    ④ 官方都这么写;
function Person(name) {
      this.name = name; // 声明成员属性
      this.say = function() { // 声明成员方法
        console.log('haha')
      }
    }
    Person.prototype.sex='female';
    var person=new Person('chaiting');
    person.age=18; // 追加成员属性
    for(keys in person){
      if(person.hasOwnProperty(keys)){
        console.log(person[keys]) // 未打印出'female'
      }
    }

七、prototype扩展内置函数
     我们通过使用prototype扩展内置函数的方法,可以直接使用内置函数的对象,调用我们扩展的方法;

// 为Array类添加一个find(val)方法,当一个Array对象调用该方法的时候,如果能找到val值,则返回其下标,否则返回-1
Array.prototype.find = function(val) {
      for (var i = 0; i < this.length; i++) {
        if (this[i] == val) {
          return i;
        }
      }
      return -1;
    }
    var arr = new Array(1, 2, 3, 4, 5);
    console.log(arr.find(1)); // 0

参考:https://www.cnblogs.com/jerehedu/p/7495098.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,753评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,668评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,090评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,010评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,054评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,806评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,484评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,380评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,873评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,021评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,158评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,838评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,499评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,044评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,159评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,449评论 3 374
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,136评论 2 356

推荐阅读更多精彩内容