今日长缨在手,何时缚住苍龙。这篇文章主要讲述#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学习笔记四十复杂工厂模式】
以上就是复杂工厂模式的理解
推荐阅读
- 客快物流大数据项目(Docker应用部署)
- python常用标准库(时间模块time和datetime)
- 译Golang 的艺术哲学和科学 #导入Word文档图片#
- k8scfssl证书工具使用手册,如何详细的学习cfssl的使用()
- It‘s likely that neither a Result Type nor a Result Map was specified
- ps扣玻璃杯
- 世上根本没有什么感同身受,只有冷暖自知
- tree树状图表格的呈现,数据结构
- HB打包的apk进行升级