JavaScript设计模式-4.继承和聚合
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>javascript高级语法4-继承和聚合</title>
</head>
<body>
<script> //继承
//创建人员类
function Person(name){
this.name = name;
}
//创建教师类
function Teacher(name,books){
//call方法可以将一个函数的对象上下文从初始化变成由this来决定。
//调用Person的构造函数,因为person没有new,所以是空对象。
Person.call(this,name);
this.books = books;
}
// 使教师类继承人员类
Teacher.prototype = new Person();
Teacher.prototype.constructor = Teacher;
Teacher.prototype.getBook = function(){
return this.name +" "+this.books;
} //测试
var jim = new Teacher("JIm","extjs4");
//alert(jim.getBook()); // 创建extend函数为了程序中所有的继承操作
function extend(subClass,superClass){
//1.让子类的原型类属性等于父类的原型属性。
// 初始化一个中间空对象,为了转换子父类关系。
var F = function(){};
F.prototype = superClass.prototype;
//2.让子类继承F
subClass.prototype = new F();
subClass.prototype.constructor = subClass;
//3.为子类增加superClass属性
subClass.superClass = superClass.prototype;
//4.增加一个保险,就算原型类是超级类(Object)那么也要把你的构造函数级别降下来。
if(superClass.prototype.constructor = Object.prototype.constructor){
superClass.prototype.constructor = superClass;
}
}
//测试
function Author(name,books){
Author.superClass.constructor.call(this,name);//低耦合
//person.call(this,name) // 高耦合
this.books = books;
this.getBook = function(){
return this.name +" "+this.books;
}
}
//继承
extend(Author,Person); var peter = new Author("张丹","javascript");
alert(peter.getBook()); //聚合
//第一种:原型上方法的聚合
//掺元类: 有时候不需要严格的继承,真正需要的是一个类(几个类)中的一些函数。
var JSON = {};
JSON.prototype = {
changeString:function(){
var output = [];
for(key in this){
output.push(key+"-->"+this[key]);
}
return output;
} }
//制作聚合函数
function mixin(receivingClass,givingClass){
for(method in givingClass.prototype){
// 本类中没有这个函数情况下再聚合,否则跳过
if(!receivingClass.prototype[method]){
receivingClass.prototype[method] = givingClass.prototype[method];
}
}
};
//var o = {name:"zhangdan",age:27};
var o = function(){
this.name = "zhangsan";
this.age = 27;
}
mixin(o,JSON);
var a = new o();
document.write(a.changeString().join(",")) //第二种:类中的函数聚合
var JSON2 = {
toChange:function(){
var output = [];
for(key in this){
output.push(key+"--》"+this[key]);
}
return output;
}
}
//聚合函数
function mixin2(receivingClass,givingClass){
for(method in givingClass){
if(!receivingClass.__proto__[method]){
receivingClass.__proto__[method] = givingClass[method];
}
}
}
var s = {name:"zhangdan",age:30};
mixin2(s,JSON2);
document.write(s.toChange().join(","))
</script>
</body>
</html>
JavaScript设计模式-4.继承和聚合的更多相关文章
- 《javascript设计模式》笔记之第四章:继承
一:首先,一个简单的继承实例: 首先是创建一个父类Person: function Person(name) { this.name = name; } Person.prototype.getNam ...
- 《JavaScript设计模式 张》整理
最近在研读另外一本关于设计模式的书<JavaScript设计模式>,这本书中描述了更多的设计模式. 一.创建型设计模式 包括简单工厂.工厂方法.抽象工厂.建造者.原型和单例模式. 1)简单 ...
- 《JavaScript设计模式与开发实践》整理
最近在研读一本书<JavaScript设计模式与开发实践>,进阶用的. 一.高阶函数 高阶函数是指至少满足下列条件之一的函数. 1. 函数可以作为参数被传递. 2. 函数可以作为返回值输出 ...
- 常用的Javascript设计模式
<parctical common lisp>的作者曾说,如果你需要一种模式,那一定是哪里出了问题.他所说的问题是指因为语言的天生缺陷,不得不去寻求和总结一种通用的解决方案. 不管是弱类型 ...
- 《Javascript设计模式与开发实践》--读书笔记
第2章 this call apply bind()方法创建一个新的函数,在bind()被调用时,这个新函数的this被bind的第一个参数指定,其余的参数将作为新函数的参数供调用时使用. bind( ...
- JavaScript设计模式经典-面向对象中六大原则
作者 | Jeskson来源 | 达达前端小酒馆 1 主要学习JavaScript中的六大原则.那么六大原则还记得是什么了吗?六大原则指:单一职责原则(SRP),开放封闭原则(OCP),里氏替换原则( ...
- 21种JavaScript设计模式最新记录(含图和示例)
最近观看了<Javascript设计模式系统讲解与应用>教程,对设计模式有了新的认识,特在此做些记录. 一.UML 文中会涉及众多的UML类图,在开篇需要做点基础概念的认识.以下面的图为例 ...
- javascript设计模式实践之职责链--具有百叶窗切换图片效果的JQuery插件(三)
在上一篇<javascript设计模式实践之模板方法--具有百叶窗切换图片效果的JQuery插件(二)>里,通过采用模板方法模式完成了切换效果对象的构建编写. 接下来就是完成各效果对象的调 ...
- javascript设计模式实践之模板方法--具有百叶窗切换图片效果的JQuery插件(二)
在上一篇<javascript设计模式实践之迭代器--具有百叶窗切换图片效果的JQuery插件(一)>里,通过采用迭代器模式完成了各初始化函数的定义和调用. 接下来就要完成各个切换效果的编 ...
随机推荐
- ETL 运行维护
装载数据仓库过程中,不管作业是实时执行还是批处理方式执行,其调度时间,执行顺序和执行环境都是关键点. 本章描述创建一个ETL操作策略,来保证数据仓库的数据即时可用. ETL执行策略分为两种:1 调度 ...
- C#基础入门 五
C#基础入门 五 递归 递归调用:一个方法直接或间接地调用了它本身,就称为方法的递归调用. 递归方法:在方法体内调用该方法本身. 递归示例 public long Fib(int n) { if(n= ...
- spring+quartz的任务调度
公司网站有个功能是自动投标,还有定时更新用户的排名信息,这些都是spring+quartz实现的. 手机了一些资料,做一个小demo,加深理解,记录一下,以后使用的时候不会出什么问题. 需要的包,主要 ...
- [react002] component基本用法
1 什么是component 设计接口的时候,把通用的设计元素(按钮,表单框,布局组件等)拆成接口良好定义的可复用的组件. 这样,下次开发相同界面程序时就可以写更少的代码,也意义着更高的开发效率,更少 ...
- Vsual Studio 高版本打开低版本项目的方法
https://www.cnblogs.com/jmliao/p/5594179.html
- tinymce与prism代码高亮实现及汉化的配置
简单介绍:TinyMCE是一个轻量级的基于浏览器的所见即所得编辑器,由JavaScript写成.它对IE6+和Firefox1.5+都有着非常良好的支持.功能方强大,并且功能配置灵活简单.另一特点是加 ...
- WM_COPYDATA+BHO+Qt实现进程间通信
最近项目有一个需求:点击网页上某个按钮,通知Qt客户端.网页相关操作使用了BHO,BHO与Qt通信通过WB_COPYDATA,为什么这么麻烦呢,因为项目正好用到了BHO,可能还有其他方式,能直接通过网 ...
- ADB 源码分析(一) ——ADB模块简述【转】
ADB源码分析(一)——ADB模块简述 1.Adb 源码路径(system/core/adb). 2.要想很快的了解一个模块的基本情况,最直接的就是查看该模块的Android.mk文件,下面就来看看a ...
- “全栈2019”Java第八十九章:接口中能定义内部类吗?
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- Java找那个io类-File获取功能
package com.hxzy.IOSer;import java.io.*; /* * File 的获取功能 * */public class Demo04 { public static voi ...