摘要:前言在说架构之前,先说说框架吧。在架构中就是这个转接头。当一个新框架诞生后,关注点从学习这个框架,慢慢变成了这个框架是如何设计的,解决什么样的问题。前几年使用过各种框架,小到,大到。
前言
在说 MVC 架构之前,先说说PHP框架吧。很多很多学完PHP语言的人,面对的就是PHP各种各样的框架。什么TP啊、Yii啊、CI啊,还有很流行的laravel啊等等。
他们的大部分都会说自己是基于 MVC 的架构,接着你得试着去理解 MVC 的逻辑,并尝试着用这样的逻辑去构建一个网站,然后会说 MVC 真香~
面试很多 PHP 的面试中,可能会问关于 MVC 的问题,比如 MVC 到底是什么意思,怎样理解这种架构。然而很多人的理解是 model 是模型,他对应着数据库中的表结构;view 对应着页面,用于展示;controller 主要用来写各种逻辑,关联数据和页面的显示。
以上回答基本上没有问题,但一个网站的结构真的有那么简单么?显然不是
设计在说之前,首先让我们了解一下设计模式的一种:中介者模式。一个形象的理解就是:港行插头和国行插头的转接头。
在 MVC 架构中 controller 就是这个转接头。它只负责把 model 中的数据转接给 view,对于访问者来说,他们是看不到 model 中保存的真实数据的。从另外一个角度来说,这种中介者模式可以很好的将两层数据进行友好的通信。
爬坑这种模式真的那么好么?随着业务逻辑的越来越复杂,会发现 controller 中的代码越来越多,甚至自己都不愿去调整和优化冗余代码。
但从宏观上来说,网站无非是请求多一些,表单多一些,页面多一些啊,其他也没什么了,为什么会这样呢?
没错,就是因为这样或那样的东西比较多,导致 controller 中每个方法都很长,那么能想到的解决方法就是拆分。
如果用过 yii 框架,那么你会知道最简单的办法是加一个请求form层,代码如下:
class AuthController { public function login() { $FLogin = new loginForm(); $FLogin->save(); } } // 一般在独立的文件夹中 class loginForm { public function __construct() { $post = $_POST; } public function save() { } }
以上的就是解决 controller 中 form 表单的问题,这个问题基本上能缓解很多代码问题。
发散从解决 form 层来看,其实有很多类似的问题都能解决。我们知道前端有个叫做 vue.js 的框架,它里面提到一个概念叫做 MVVM 模型。
其实在展现复杂页面的时候,后端在对外输出数据时,完全也可以采用这玩意进行数据输出。至于如何建立这样的一个模型,那就具体得看业务逻辑了。
这里简单拿用户中心举个例子,因为往往这里不仅仅需要一个表的数据:
class AuthController { public function userCenterAction() { return new userVM(); } } class userVM { public $user; public $orders; public $other; public function __construct() { $this->user = $this->getUser(); $this->orders = $this->getOrders(); $this->handle(); } private function getUser() { return NULL; } private function getOrders() { return NULL; } private function handle() { } }
以上代码中,有个 VM 层,可以将相关获取数据的代码放在各自的方法中,然后在 handle 方法中自由组合。这样在 controller 中的代码也非常便于管理。
再想想,有没有可以封装的其他层呢?其实是有的,比如 request 层,还有经常被框架封装好的 validate 层,还有 laravel 中比较流行的 Middleware 层等等。只能说系统越复杂,层越多。
每个复杂系统的背后都蕴含着高级开发工程师和架构师的设计思路。以上说那么多,不知道读者能否理解这些东西,就拿以上代码来说,里面就蕴含着另一种设计模式:建造者模式。
总结代码写多了,也就知道其中蕴含的道理了。当一个新框架诞生后,关注点从学习这个框架,慢慢变成了这个框架是如何设计的,解决什么样的问题。哪些地方用了比较好的技术和方法,从中能收获到什么。一些地方的设计思路是什么样的,有么有更好的设计,为何我能想到,对方想不到呢,是不是我遗漏了什么。
前几年使用过各种 PHP 框架,小到 CI,大到 Symfony。不用那么多框架,也体会不到这些东西。学习编程其实和英语一样,没什么捷径可以走。
多写,多想,多练......
以上
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/31012.html
摘要:但是模型中数据的变化一般会通过一种刷新机制被公布。它处理事件并作出响应。事件包括用户的行为和数据模型上的改变。三开始开发自己的框架在开始开发前,让我们先来把项目建立好,假设我们建立的项目为,那么接下来的第一步就是把目录结构先设置好。 现如今市面上有许多PHP框架,像 ThinkPHP、YII、Laravel,那么如何自己搭建一个PHP框架呢?这里有一篇博文写的非常好,特意转载过来,供朋...
摘要:的最后一个大招就是替换一些传统的服务端语言,例如,,等,在业务层上面使用来开发服务端完全不成问题。更多的的使用细节和技巧建议关注美团博客大搜车论坛下一篇我们开启如何结合和搭建一个开发环境和项目目录 往期回顾 前面2期都讲得是浏览器端的东西比较多,包括Webpack,虽然是Node处理的,但是还是浏览器端用的多,对于现在的前端开发来说,不懂一点服务端的东西,简直没办法活,一般的招聘要求都...
摘要:本文会以引出问题为主,后面有时间的话,笔者陆续会抽些重要的知识点进行详细的剖析与解答。敬请关注服务端思维微信公众号,获取最新文章。 原文地址:梁桂钊的博客博客地址:http://blog.720ui.com 这里,笔者结合自己过往的面试经验,整理了一些核心的知识清单,帮助读者更好地回顾与复习 Java 服务端核心技术。本文会以引出问题为主,后面有时间的话,笔者陆续会抽些重要的知识点进...
摘要:容器自动完成装载,默认的方式是这部分重点在常用模块的使用以及的底层实现原理。 对于那些想面试高级 Java 岗位的同学来说,除了算法属于比较「天方夜谭」的题目外,剩下针对实际工作的题目就属于真正的本事了,热门技术的细节和难点成为了主要考察的内容。 这里说「天方夜谭」并不是说算法没用,不切实际,而是想说算法平时其实很少用到,甚至面试官都对自己出的算法题一知半解。 这里总结打磨了 70 道...
阅读 1716·2021-11-22 15:33
阅读 2086·2021-10-08 10:04
阅读 3545·2021-08-27 13:12
阅读 3421·2019-08-30 13:06
阅读 1468·2019-08-29 16:43
阅读 1395·2019-08-29 16:40
阅读 787·2019-08-29 16:15
阅读 2747·2019-08-29 14:13