javascript“类”与继承总结和回顾
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“类”与继承总结和回顾的更多相关文章
- JavaScript 类式继承与原型继承
交叉着写Java和Javascript都有2年多了,今天来总结下自己所了解的Javascript类与继承. Javascript本身没有类似Java的面向对象的类与继承术语,但其基于原型对象的思想却可 ...
- javascript类式继承最优版
直接看实例代码: <!doctype html> <html lang="en"> <head> <meta charset=" ...
- JavaScript “类”定义 继承 闭包 封装
一.Javascript “类”: 类:在面向对象编程中,类(class)是对象(object)的模板,定义了同一组对象(又称"实例")共有的属性和方法. Javascript是一 ...
- 详谈Javascript类与继承
本文将从以下几方面介绍类与继承 类的声明与实例化 如何实现继承 继承的几种方式 类的声明与实例化 类的声明一般有两种方式 //类的声明 var Animal = function () { this. ...
- javascript类式继承模式#4——共享原型
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javascript类式继承模式#3——借用和设置原型
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javascript类式继承模式#2——借用构造函数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javascript类式继承模式#1——默认模式
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javascript类式继承函数最优版
直接上代码: klass函数 var klass = function (Parent, props) { var Child, F, i; //1.新构造函数 Child = function () ...
随机推荐
- swift日期操作
简介:本文将介绍一些关于swift中对于日期的格式化与获取,支持swift4.0 extension Date { //格式化日期 func getDateString() -> String{ ...
- CSS3 制作魔方 - 相关立体样式
最好的实践,就是给定一个实践的目标去实践. 目标:利用 CSS3 的一些特性,绘制一个魔方,要可以玩转的那种,即上下左右每一层都可以独立旋转.效果如下: 为了完成此效果,将使用到以下相关概念和样式:坐 ...
- Legacy C++ MongoDB Driver
https://docs.mongodb.com/ecosystem/drivers/cpp/
- Lightoj1081【500棵线段树维护】
#include <bits/stdc++.h> using namespace std; typedef long long LL; const int N=5e2+10; const ...
- CodeForces 723F【DFS瞎搞】
题意: 给你一幅图,你要用这些边构造一个树, s和t两个节点的度数不能超过ds dt 而且图是保证没有环 思路: 树的性质是:无环(已经保证),无向(保证),连通(还要判断) 首先把S,T点从图里剥离 ...
- 第二篇 Nosql讲解之windows下memcache的安装(一)
memcached基本概念 1.Memcached是danga的一个项目,最早是LiveJournal服务的,最初为了加速LiveJournal访问速度而开发的,后来被很多大型的网站采用. 官方网站: ...
- springboot2.x 的 RedisCacheManager变化
springboot2.x 的 RedisCacheManager变化 springboot2.x 的 RedisCacheManager变化 由于最近在学着使用redis做缓存,使用的是spring ...
- adb server version (39) doesn't match this client (40); killing...
在启动RN项目的时候也报错,上面的错误是在adb的环境变量中的位置和android studio的sdk不是一个位置.adb是在sdk中的,所以他们应该是一致的位置 android studio的sd ...
- rpm与yum安装软件包
首先,禁止用yum卸载删除软件包: 而应该使用rpm删除软件包 rpm qa | grep 软件包名 rpm -e --nodeps 要卸载的软件包
- laravel配合swoole使用总结
最近对接硬件做了两个项目,用到了swoole 第一个是门禁系统,需要远程开门.离线报警.定时开门.离线刷卡等功能 1.远程开门: 目前用cli创建个临时客户端连接服务端发送命令,服务端处理完成后客户端 ...