【杂谈】类与构造函数、代码结构与面相对象

前言

这或许会对新人有用,少走些弯路.
就是一些心得吧,自己的理解,刚好大部分都想起来就写下来了.
不那么标准也不绝对正确,可以参考一些.


一、类与构造函数相同?

用类写一个全局时间对象时遇到问题.
定义在类构造函数里的东西,实例化后都在对象内.
类块内的东西,实例化后是在对象原型里的.
但类块里的this是指向对象的,即要在类块内访问一个函数: this.proto. xx
等一下.
我记得那个好像叫"就近原则"? 对象里找不到就会去原型里找,是学Node时有人讲过,有些方法Node对象里没有但是在它原型的原型的…额,就是原型链里有就好,就能调用的到. 这里也一样?类块方法在原型里但是你可以直接从对象里访问到,不用过__proto__.
若是将东西全定义在构造函数里,那这个类中奏效的便只是它的构造函数,它实例化得到的对象与你实例化一个具备相同属性的构造函数是相同的,类块中的属性只是影响了对象的原型.

所以我记得有一句话在《Javascript高级程序设计》类和构造函数那块,大体是这样的意思:类与构造函数是相同的.


二、代码结构与面相对象

写javascript这几年慢慢也领悟到了一些东西,呃,是那种不好系统性说出来的东西.
只能说用说话的语气去谈一谈.

关于“面相对象”

它其实是对象与对象去交流,我说的这个对象它是“type”的那种对象类型,所以是说面相对象,就是你去构建对象然后让对象去交流通讯,在这个过程中产生出你需要的数据,完成你的目标.
但是我想几乎每个,包括我在内的javascript初学者入门时都被灌输过一个理念,即javascript里万物皆是对象,我现在觉得这是不对的,就那种数字类型字符串类型这种简单基础数据类型它自己就没什么内涵(虽然它上面也是有一些方法属性,也是通过实例化出来的对象,但是站在一个开发者的角度没必要把这种简单数据类型也看作一种对象吧).
那说的有点远了,回到对象通讯,简单数据类型它们之间有什么好通讯的?就把它们算做是对象,他们之间有什么可以交换的数据吗?
看下那些库,和原生项目,基本都是在用构建大对象,一个大对象作为专司一部分功能的模块.

对象交流

比如在一个网页游戏里写一个专门管理时间的对象,那里面就要有为其他对象处理有关时间的问题的方法.
比如人物获得了一个异常状态每秒要扣1滴血,不面相对象散开写,你可能就直接hp–,但是面相对象,你就构建一个人物对象,里面的属性就是这个人物的数据,方法就是这个人物能做的事和技能,然后每秒要扣血的话你就要让他的hp每秒减. 但这个算时间的工作在一个上下文里可能会有很多吧?你每个单位都弄个计时器各自算各自的最后就是时间不统一性能又差然后到处都是定时器也不好维护.
你就做一个专门管时间的对象,大家都共用这个时间对象里的那一个定时器,性能就会好一些.
然后你还可以在对象里做个表去存大家的定时工作回调,就是在这个对象里再维护一个数组嘛,你学过栈模型的话大概会好理解:暴露出一个方法去收集这是谁委托过来的定时工作,即收集一个回调函数,收集在多少秒内有效,收集多少秒调用一次,然后时间管理器到了时间便去调用别人委托来的定时任务,这样是不是就整齐划一了?大家的定时工作就都来这里处理了,然后回调函数还可以带着时间管理器传的参数回到自己的对象.
我记得vue里也有个类似的结构,就是收集虚拟dom集中监听,然后监听到数据有变化的话再去通知某个部位改变,这也是一个收集管理通知的结构,不过简单许多?
这就是两个对象在交流吧,起初我是构建过这种结构出来,这不难的.

代码结构

但是有时候写的方法和对象里的内容不合理,某一天我意识到的,比如你实例化了一堆子对象交给专门管理这种类型的管理器对象去维护,那子对象和子对象之间是不该互相交换属性和存储各自的属性吧,可以那样写,但是是不太合理吧?它们每个个体都是泡在管理器环境里的,并不是紧挨着,你应该让他们通过管理器这一层去交流,而不是这p2p一样的直接对话交换数据,这种结构里在一个子对象里存另一个子对象也不合理,存了,这个个体便不再纯净了吧?你要访问对象B居然还能通过对象A访问,这是不太合理的.
你得注意两个需要交流的对象他们是上下级还是平级,平级就要考虑是不是要都放进第三方介质,即共同上级里去通过介质交流,这样有助于维持下面所说的“金字塔一般的结构”.

对象的层级

大结构方面就有这种底层和高层的概念,“金字塔一般的结构”.
比如我先去做一个石头类,一堆石头类去交给屋子类管理,构成屋子类,然后屋子类这条线就到头了吧?
我再去构建一个血肉类,一堆血肉又交给鸟类维护加上鸟类的自有属性构成鸟类,然后我再有个地板类把所有地上的东西放到这个类里维护,再构建一个天空类把所有天上的东西都放到这个类里维护,最后我在world类里把天空和地面类实例化出来维护,是吧,这样最底层就是石头和血肉,二层是屋子和飞鸟,三层是地面天空,顶层是world,然后我把world对象暴露出去,这不是就全都暴露出去了.

层级间联携调动

然后管理操作上,你比如说我要去发起world更新,然后world维护了地面和天空吧?world的更新方法完成自己的工作后还要去调天空和地面的更新方法(你不能越级调吧,越级调用你要过天空地面去访问,但天空地面还没更新呢)天空地面更新完自己再去叫自己维护的所有东西更新,那屋子和飞鸟的更新方法就被调用了,它们完成了自己的工作再去调用它们维护的东西遍历更新.
这种结构vue里也有吧.
这就完成了,world一更新,小到一个石头粒一个细胞都被更新了,顶层是牵一发而动全身的头羊,下面的对象出问题不会影响上层对象,只是它自己会出问题,不会出现“底层代码改不得”之类的问题.

唉,暂时就想到这么多,如有不妥还请指正.

上一篇:Python 小高考篇(5)自定义函数-总结