两个月时间抽空从前端的角度总结了一下设计模式

2022-03-11 07:26:19 +08:00
 windliang

从 1 月 6 号开始利用两个月的时间把 23 个设计模式都过了一遍,详细总结了其中的 12 个,都结合了前端实际开发中遇到的场景。

撸了个网站把总结放了上去,读起来会更方便,欢迎阅读,欢迎拍砖:

pattern.windliang.wang

每个设计模式的原始定义其实很好理解,直接打开维基百科看看定义、看看代码十几分钟估计就能了解一个,最重要的地方在于实际开发场景中的到底有哪些例子。

这方面的话前端相关的例子很少很少,我自己的经验有限,非常欢迎大家在 github 给我提 issues,把大家应用过或者见过的设计模式写一下,一起学习,一起进步!

3217 次点击
所在节点    分享创造
25 条回复
murmur
2022-03-11 08:03:30 +08:00
设计模式学多了容易魔怔,就你那个装饰器,我写个函数 makeMilkTea({Peral: 1, coconut: 2})他不香么,

前端和后端不一样,前端是搭积木,我不希望搞出个 car->iron car->car with air condition 的奇葩功能

我需要的是 superCar({airCondition: true}),你不行我就换一个行的组件用
murmur
2022-03-11 08:08:29 +08:00
这里不得不说一下以前 jq-easyui 的设计,panel->window->dialog 的继承,都魔怔了

首先 panel 在现在前端,就是个纯 css 样式,没啥 js 功能

window 和 dialog 差了什么,不就差个按钮么,那做一个 slot ,当时没有 vue 我做成选项不行么

所以我需要这么正统的继承关系么?我需要的是$.dialog({title: false, buttons: false}
ericls
2022-03-11 08:18:04 +08:00
做事情要从问题出发 不能从答案出发
gouflv
2022-03-11 08:24:29 +08:00
感谢分享
37Y37
2022-03-11 08:28:51 +08:00
前端竟然有这么多设计模式?
windliang
2022-03-11 09:04:50 +08:00
@murmur 总结的时候是按两个例子来讲,makeMilkTea 的例子是为了理解设计模式,纯虚构,没什么用。另一个例子是实际开发中用到的
windliang
2022-03-11 09:06:47 +08:00
@murmur 前端的组件继承确实很尴尬,毕竟 React 也推出了 hooks ,放弃了 class 。因为这个原因所以很多设计模式在前端根本用不上,总结里也提到了
murmur
2022-03-11 09:08:10 +08:00
@windliang 那问题来了,就你的例子来说,Object.assign 或者库的 deep-extend 属于装饰器么

我认为过于牵强,尤其是 Object.assign 属于内置函数
windliang
2022-03-11 09:09:37 +08:00
@ericls 是的,所以我都是尽可能的举了实际开发中遇到的例子,没有遇到的也没有去总结了。也希望大家遇到过的可以分享下
murmur
2022-03-11 09:10:49 +08:00
我的例子是针对"将传入的 option 进行装饰返回即可"这句话,也许实现跟你的想法不一样

毕竟 java 的装饰器可是装饰 Stream 那个类,前端很难想出这样的场景来
windliang
2022-03-11 09:15:33 +08:00
@murmur 我理解的话,设计模式是结合场景来说的,Object.assign 就是提供的工具,就看怎么用了,如果符合装饰器的结构就行。因为 js 不需要 class 去生成对象,所以和原始的设计模式比起来确实有些牵强,但如果思想是一样的,我就归类为某个设计模式了。
windliang
2022-03-11 09:17:17 +08:00
@murmur 因为 js 不需要类,就很尴尬,所以只能尽可能的理解设计模式本身的想法,然后在结合下 js 再应用
windliang
2022-03-11 09:18:46 +08:00
@37Y37 理论上设计模式只是思想,和前端、后端没关系,但 js 是基于原型的面相对象,不是基于 class 的面向对象,网上也没有很多例子,所以我就总结了一下,希望抛砖引玉
ericls
2022-03-11 09:20:04 +08:00
@windliang 设计模式不是思想 只是对现有问题的有可能的解答的列举
windliang
2022-03-11 09:20:25 +08:00
@gouflv 发现问题一起交流!
yaphets666
2022-03-11 09:30:57 +08:00
@ericls 模式和思想这两个词可以画等号的
chiaf
2022-03-11 09:36:03 +08:00
[免费在线学习代码重构和设计模式]( https://refactoringguru.cn)

设计模式可以看看这个网站
ericls
2022-03-11 10:00:47 +08:00
@yaphets666 思想都套进模式了 那还有什么 innovation
windliang
2022-03-11 10:22:52 +08:00
@chiaf 我的总结里也提到了,很不错的网站,但也主要是基于 class 的面向对象,很希望有对前端场景具体应用的设计模式的例子,所以我就又总结了一下,也希望更多人一起来
JunC74
2022-03-11 10:31:13 +08:00
谢谢分享,设计模式是不错的方案,但是在很多情况下并不是最合适的.但一定是可行的.

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/839561

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX