Javascipt语法不支持"类"(class)[es6已经支持],但是有模拟类的方法。今天我主要谈谈Javascipt中模拟“类”的方法及js中继承的总结和回顾。

js中实现“类”与继承,既是重点,又是难点。很多同学可能都对js中“类”与继承都有所了解,但是深入剖析的时候,感觉力不从心、模棱两可。

下面我们一起来总结一下,巩固提高一下js的基础知识。关于js的基础知识,我在之前写过一个关于js老生常谈之this,constructor ,prototype; 有兴趣的同学可以去深入了解一下!

我们先来总结一下js定义“类”的几种方法:

方法一:构造函数法

这个方法是比较经典的方法,我们会经常见到。生成实例的时候,使用new关键字。类的属性和方法,还可以定义在构造函数的prototype对象之上。

function Person(name,age,job){
this.name=name;
this.age=age;
this.job=job;
} Person.prototype.sayName=function(){
alert(this.name);
} var person1 = new Person("张三","29","web frontpage manager");
var person2 = new Person("李四","22","doctor"); person1.sayName(); //弹出"张三"
console.log(person2.name)//输出“李四”

  

方法二:Object.create()法

方法Object.creat()作为new操作符的替代方案是ES5之后才出来的。用这个方法,"类"就是一个对象,不是函数。

var myMammal = {
name : 'Herb the Mammal',
get_name : function () {
return this.name;
},
says : function () {
return this.saying || '';
}
} var myCat = Object.create(myMammal);
myCat.name = 'Henrietta';
myCat.saying = 'meow';
myCat.get_name = function () {
console.log(this.says + ' ' + this.name + this.says);
} myCat.get_name();

  输出:

function () {
return this.saying || '';
} Henriettafunction () {
return this.saying || '';
}

  目前,各大浏览器的最新版本(包括IE9)都部署了这个方法。如果遇到老式浏览器,可以用下面的代码自行部署。

  if (!Object.create) {
    Object.create = function (o) {
       function F() {}
      F.prototype = o;
      return new F();
    };
  }

  

方法三:极简主义法

封装

这种方法不使用this和prototype,代码部署起来非常简单。 首先,它也是用一个对象模拟"类"。在这个类里面,定义一个构造函数creatFn(),用来生成实例。

var Dog= {
    creatFn: function(){
      // some code here
    }
  };

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

var Dog= {
    creatFn: function(){
      var dog= {};
      dog.name = "狗狗";
      dog.makeSound = function(){ alert("汪汪汪"); };
      return dog;
    }
  };

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

 var dog1 = Dog.creatFn();
  dog1.makeSound(); // 汪汪汪

  

这种方法的好处是,容易理解,结构清晰优雅,符合传统的"面向对象编程"的构造,因此可以方便地部署下面的特性。

继承

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

var Animal = {
    creatFn: function(){
      var animal = {};
      animal.eat= function(){ alert("吃饭饭"); };
      return animal;
    }
  };

  然后,在Dog的creatFn()方法中,调用Animal的creatFn()方法。

  var Dog= {
    creatFn: function(){
      var dog= Animal.creatFn();
      dog.name = "狗狗";
      dog.makeSound = function(){ alert("汪汪汪"); };
      return dog;
    }
  };

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

var dog1= Dog.creatFn();
  dog1.eat(); // 吃饭饭

  

私有属性和私有方法

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

var Dog= {
    creatFn: function(){
      var dog= {};
      var sound = "汪汪汪";
      dog.makeSound = function(){ alert(sound); };
      return dog;
    }
  };

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

var dog1 = Dog.creatFn();
  alert(dog1.sound); // undefined

  

数据共享

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

  var Dog= {
    sound : "汪汪汪",
    creatFn: function(){
      var dog= {};
      dog.makeSound = function(){ alert(Dog.sound); };
      dog.changeSound = function(x){ Dog.sound = x; };
      return dog;
    }
  };

  然后,生成两个实例对象:

var dog1 = Dog.creatFn();
  var dog2 = Dog.creatFn();
  dog1.makeSound(); // 汪汪汪

  这时,如果有一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。

  dog2.changeSound("呜呜呜");
  dog1.makeSound(); //呜呜呜

  

javascript“类”与继承总结和回顾的更多相关文章

  1. JavaScript 类式继承与原型继承

    交叉着写Java和Javascript都有2年多了,今天来总结下自己所了解的Javascript类与继承. Javascript本身没有类似Java的面向对象的类与继承术语,但其基于原型对象的思想却可 ...

  2. javascript类式继承最优版

    直接看实例代码: <!doctype html> <html lang="en"> <head> <meta charset=" ...

  3. JavaScript “类”定义 继承 闭包 封装

    一.Javascript “类”: 类:在面向对象编程中,类(class)是对象(object)的模板,定义了同一组对象(又称"实例")共有的属性和方法. Javascript是一 ...

  4. 详谈Javascript类与继承

    本文将从以下几方面介绍类与继承 类的声明与实例化 如何实现继承 继承的几种方式 类的声明与实例化 类的声明一般有两种方式 //类的声明 var Animal = function () { this. ...

  5. javascript类式继承模式#4——共享原型

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. javascript类式继承模式#3——借用和设置原型

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. javascript类式继承模式#2——借用构造函数

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. javascript类式继承模式#1——默认模式

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. javascript类式继承函数最优版

    直接上代码: klass函数 var klass = function (Parent, props) { var Child, F, i; //1.新构造函数 Child = function () ...

随机推荐

  1. LeetCode: 258 Add Digits(easy)

    题目: Given a non-negative integer num, repeatedly add all its digits until the result has only one di ...

  2. Node中的console控制台

    1. Node中的console类似于浏览器中的控制台console,它的作用在于帮助开发人员做API的辅助测试. 2. Node中的console主要功能:REPL 2.1 read 读取你输入的内 ...

  3. Codeforces691A【读题-水】

    妈蛋wa了两次.. 时尚的定义是length大于1的要破个洞,一定要破个洞.. According to rules of the Berland fashion, a jacket should b ...

  4. perl 打开二进制文件,并拷贝内容

    实现脚本 use strict ; my $fileName = "/Users/chenfool/Desktop/sequoiadb-大数据平台构建.pdf" ; my $out ...

  5. localStorage和sessionStorage使用

    localStorage.setItem("key","value");//存数据 localStorage.getItem("key"); ...

  6. django_auth模块

    auth是django提供的标准权限管控系统,可以提供用户的身份认证.用户组和权限管理. auth可以和admin配合使用,可以快速建立网站的管理系统. USER user用于维护系统的用户信息,在数 ...

  7. Codeforces Round #396 (Div. 2) B

    Mahmoud has n line segments, the i-th of them has length ai. Ehab challenged him to use exactly 3 li ...

  8. Dwarves, Hats and Extrasensory Abilities Codeforces - 1063C

    https://codeforces.com/contest/1063/problem/C 首先可以想到一个简单做法:先钦定这个直线的斜率k=-1,然后设直线y=-x+b 设黑点放直线上方:如果已知( ...

  9. 修正 FreeBSD 字体锯齿问题

    如果你给 FreeBSD 安装完图形界面,一登录就被满屏幕不论中英全是锯齿且残缺不堪入目的文字吓了一跳,那一定是安装了文泉驿字体.先不必急着卸载文泉驿,只需简单修改相关配置即可恢复正常显示.这是因为文 ...

  10. Dubbo端口占用错误信息

    SEVERE: Exception sending context initialized event to listener instance of class com.common.SysCont ...