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 () ...
随机推荐
- 洛谷 - P2051 - 中国象棋 - 简单dp
https://www.luogu.org/problemnew/show/P2051 一点都不简单的简单dp. 还是从旧行转移到新行,而不是考虑新行从哪些旧行转移吧. #include<bit ...
- MyBatis中的RowBounds
myBatis中实现分页的方式是采用RowBounds这个类,用法如下,xml语句不变 传入两个参数,strat起始行, limit是当前页显示多少条数据,原理是RowBounds在处理分页时,只是简 ...
- [Xcode 实际操作]九、实用进阶-(3)给代码方法添加宏注释
目录:[Swift]Xcode实际操作 本文将演示如何在方法列表中,对方法名称进行注释. 这样可以使程序,按功能分块,使方法清晰.易读并且方便定位. 在项目导航区,打开视图控制器的代码文件[ViewC ...
- XCode5 编译ffmpeg流程
今天想在Mac10.9 XCode5的环境下把ffmpeg编译出来,本来以为很好搞定,结果版本一升级,以前的命令行不通了,出各种错误.折腾了三四个小时,最后终于成功了. 编译流程: 1.ffmpeg官 ...
- D - Fliptile
#include <stdio.h> #include <iostream> #include <math.h> #include <algorithm> ...
- D. Merge Equals(from Educational Codeforces Round 42 (Rated for Div. 2))
模拟题,运用强大的stl. #include <iostream> #include <map> #include <algorithm> #include < ...
- nginx 设置websocket支持
#websocket======相关 proxy_read_timeout 60m; proxy_http_version 1.1; proxy_set_header Upgrade $http_up ...
- java多线程模拟红绿灯案例
代码Lighter.java: package pack1; /** * 灯线程 * @author Administrator * */ public class Lighter extends T ...
- 【loj10064】黑暗城堡
#10064. 「一本通 3.1 例 1」黑暗城堡 内存限制:512 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 上传者: 1bentong 提交 ...
- Codeforces 1142B(倍增)
1.先预处理出在循环中某数前面的数是谁. 2.读入a数列时贪心选取最晚的父亲. 3.链上倍增预处理二进制祖先. 4.对于每个位置,预处理第n-1个祖先位置最早要从哪里开始,技巧上再顺手与前一位的最早位 ...