#yyds干货盘点# js学习笔记四十复杂工厂模式

今日长缨在手,何时缚住苍龙。这篇文章主要讲述#yyds干货盘点# js学习笔记四十复杂工厂模式相关的知识,希望能为你提供帮助。


前言



我是歌谣 我有个兄弟 巅峰的时候排名c站总榜19 叫前端小歌谣 曾经我花了三年的时间创作了他 现在我要用五年的时间超越他 今天又是接近兄弟的一天人生难免坎坷 大不了从头再来 歌谣的意志是永恒的 放弃很容易 但是坚持一定很酷


导语


复杂工厂模式



代码部分
//第一步 定义自行车的构造函数 两个属性 一个name和一个方法method
var BicycleShop = function(name)
this.name = name;
this.method = function()
return this.name;

;
BicycleShop.prototype =
constructor: BicycleShop,
/*
* 买自行车这个方法
* @param model 自行车型号
*/
sellBicycle: function(model)
var bicycle = this.createBicycle(model);
// 执行A业务逻辑
bicycle.A();

// 执行B业务逻辑
bicycle.B();

return bicycle;
,
createBicycle: function(model)
throw new Error("父类是抽象类不能直接调用,需要子类重写该方法");

;
// 实现原型继承Sub表示子类,Sup表示超类
function extend(Sub,Sup)

// 首先定义一个空函数
var F = function();

// 设置空函数的原型为超类的原型
F.prototype = Sup.prototype;

// 实例化空函数,并把超类原型引用传递给子类
Sub.prototype = new F();

// 重置子类原型的构造器为子类自身
Sub.prototype.constructor = Sub;

// 在子类中保存超类的原型,避免子类与超类耦合
Sub.sup = Sup.prototype;

if(Sup.prototype.constructor === Object.prototype.constructor)
// 检测超类原型的构造器是否为原型自身
Sup.prototype.constructor = Sup;


var BicycleChild = function(name)
this.name = name;
// 继承构造函数父类中的属性和方法
BicycleShop.call(this,name);
;
// 子类继承父类原型方法
extend(BicycleChild,BicycleShop);
// BicycleChild 子类重写父类的方法
BicycleChild.prototype.createBicycle = function()
var A = function()
console.log("执行A业务操作");
;
var B = function()
console.log("执行B业务操作");
;
return
A: A,
B: B


var childClass = new BicycleChild("龙恩");
console.log(childClass);


总结


以上就是复杂工厂模式的理解


【#yyds干货盘点# js学习笔记四十复杂工厂模式】


    推荐阅读