[设计模式] javascript 之 模板方法模式

模板方法模式说明

定义:定义方法操作的骨架,把一些具体实现延伸到子类中去,使用得具体实现不会影响到骨架的行为步骤!

说明:模式方法模式是一个继承跟复用的典型模式,该模式定义了一个抽象类,Abstract Class,其下定义了一个或多个模板方法,也就是顶级方法,这些方法定义行为的调度步骤,一般是调用抽象中定义的其他具体类或勾子;定义了一些抽象方法,这些方法必须要由具体子类来实现;还有可能定义了一些勾子方法,这一般是空方法,用于子类扩展。

模板方法模式组成:

1>. 模板方法: 也叫骨架方法,定义行为调度步骤! 不能被子类修改,如果在java高级面向对象语言,一般会以 final 修饰!

2>. 抽象方法:待子类继承必须实现的方法;

3>. 具体方法:用于在抽象类中的顶级实现,一般也不能被覆盖修改,一般也会加上 final 修饰!

4>. 勾子方法: 一般为空方法. 方法命名一般以 “do” 开头,类似于 HttpServlet 下的 doGet, doPost;

模板方法模式,一般用于 具有相同行为逻辑过程,但各自实现不太一样的场景,这种情况就可以采用这种模式,定义骨架,规定如何去执行,顺序、调度等,再让子类各自去实具体的行为;

面向对象思想,要注意它不变跟变化的因素,在模板方法模式里,行业逻辑是不变的,行为具体实现是可变的,把可变跟不可变的分离使之解藕,这符合面向对象的开闭原则;定义抽象骨架,让具体实现以子类形式去自由扩展,互不影响。

模板模式结构图:

实例场景:

1>. 比如不同文件审批上呈过程,经过的人或部门是一样的,但每个过程他的处理是不一致的;

2>. 再比如说,大学四年,不同专业每年所修的课本是不太一样的;

实例源码

这里以读大学四年来实现;

1. 定义抽象类;

function AbstractClass() {
    
}

AbstractClass.prototype.template = function() {
    this.FirstYear();
    this.SecondYear();
    this.ThirdYear();
    this.FourthYear();
}

AbstractClass.prototype.FirstYear = function() {
    console.log('需要重写');
}

AbstractClass.prototype.SecondYear = function() {
    console.log('需要重写');
}

AbstractClass.prototype.ThirdYear = function() {
    console.log('需要重写');
}

AbstractClass.prototype.FourthYear = function() {
    console.log('需要重写');
}

2. 定义某学生;

function Student(name) {
    this.name = name;
}

Student.prototype = AbstractClass.prototype; //继承

Student.prototype.FirstYear = function() {
    console.log(this.name+' 第一年修: 语文' );
}

Student.prototype.SecondYear = function() {
    console.log(this.name+' 第二年修: 数学' );
}

Student.prototype.ThirdYear = function() {
    console.log(this.name+' 第三年修: 英语' );
}

Student.prototype.FourthYear = function() {
    console.log(this.name+' 第四年修: 历史' );
}

3. 使用方法:

var student = new Student('陈某某');
student.template();

输出:

陈某某 第一年修: 语文

陈某某 第二年修: 数学

陈某某 第三年修: 英语

陈某某 第四年修: 历史

其他说明

面向对象中的继承,一般把行为方法置于最顶层,把状态成员,置于子类当中;关注行为,而非状态;

模板方法模式是一个经常用到的模式,体现了面向对象经典的继承跟复用特点;用于关注固定的逻辑行为,骨架方法用于封装固定的逻辑过程,开发时要提取这部分统一的过程到抽象类中去,抽象与具体的设计师分工开发时就可以不受其他影响;

关健字:模板,继承,骨架;

欢迎您的到来,感谢您的支持!

为您推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注