js的类与继承

鉴于长时间不写前端代码以至于很多复杂的js代码拿过来读都有点吃力,就把一些知识点总接起来。

首先巩固下知识:

js把对象分为俩种其一是普通对象(Object自带对象)其二是函数对象(Function自带对象), new Function()出来的是函数对象其他则为普通对象;当然很多时候你看到的当然不是很直白的这种形式,就像函数对象创建就有多种形式。

在JavaScript 中,每当定义一个对象(函数)时候,对象中都会包含一些预定义的属性。其中函数对象的一个属性就是原型对象 prototype。注:普通对象没有prototype,但有proto属性。
看下例子
function f1(){};
console.log(f1.prototype) //f1{}
console.log(typeof f1. prototype) //Object
console.log(typeof Function.prototype) // Function,这个特殊
console.log(typeof Object.prototype) // Object
console.log(typeof Function.prototype.prototype) //undefined

1.js的类对象申明的创建:

1)原型:

function Cat() {
    this.name = "大毛";
  }
var cat1 = new Cat();
alert(cat1.name); // 大毛
Cat.prototype.makeSound = function(){
  alert("喵喵喵");
}

2)、Object.create()法

 var Cat = {
    name: "大毛",
    makeSound: function(){ alert("喵喵喵"); }
  };
  var cat1 = Object.create(Cat);
  alert(cat1.name); // 大毛
  cat1.makeSound(); // 喵喵喵

3)、极简主义法
这种方法不使用this和prototype,代码部署起来非常简单,这大概也是它被叫做”极简主义法”的原因。
首先,它也是用一个对象模拟”类”。在这个类里面,定义一个构造函数createNew(),用来生成实例。

var Cat = {
    createNew: function(){
      // some code here
    }
  };

然后,在createNew()里面,定义一个实例对象,把这个实例对象作为返回值。

var Cat = {
    createNew: function(){
      var cat = {};
      cat.name = "大毛";
      cat.makeSound = function(){ alert("喵喵喵"); };
      return cat;
    }
  };

使用的时候,调用createNew()方法,就可以得到实例对象。

 var cat1 = Cat.createNew();
  cat1.makeSound(); // 喵喵喵

让一个类继承另一个类,实现起来很方便。只要在前者的createNew()方法中,调用后者的createNew()方法即可。
先定义一个Animal类

var Animal = {
    createNew: function(){
      var animal = {};
      animal.sleep = function(){ alert("睡懒觉"); };
      return animal;
    }
  };

然后,在Cat的createNew()方法中,调用Animal的createNew()方法。

var Cat = {
    createNew: function(){
      var cat = Animal.createNew();
      cat.name = "大毛";
      cat.makeSound = function(){ alert("喵喵喵"); };
      return cat;
    }
  };

这样得到的Cat实例,就会同时继承Cat类和Animal类。

var cat1 = Cat.createNew();
  cat1.sleep(); // 睡懒觉

私有属性和私有方法

在createNew()方法中,只要不是定义在cat对象上的方法和属性,都是私有的

 var Cat = {
    createNew: function(){
      var cat = {};
      var sound = "喵喵喵";
      cat.makeSound = function(){ alert(sound); };
      return cat;
    }
  };

上例的内部变量sound,外部无法读取,只有通过cat的公有方法makeSound()来读取。

var cat1 = Cat.createNew();
  alert(cat1.sound); // undefined

数据共享
有时候,我们需要所有实例对象,能够读写同一项内部数据。这个时候,只要把这个内部数据,封装在类对象的里面、createNew()方法的外面即可。

 var Cat = {
    sound : "喵喵喵",
    createNew: function(){
      var cat = {};
      cat.makeSound = function(){ alert(Cat.sound); };
      cat.changeSound = function(x){ Cat.sound = x; };
      return cat;
    }
  };
  var cat1 = Cat.createNew();
  var cat2 = Cat.createNew();
  cat1.makeSound(); // 喵喵喵
  //这时,如果有一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。
   cat2.changeSound("啦啦啦");
  cat1.makeSound(); // 啦啦啦

原文:http://www.ruanyifeng.com/blog/2012/07/three_ways_to_define_a_javascript_class.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值