Yii2 Day4: 模块化开发

困境

做了几年Windows环境下程序开发(大概200多个模块,几百万行代码),转做PHP Web开发后,发现模块级别的代码重用实在是不如意啊,重用基本上都是代码复制粘贴级别的,耦合度都太高,不利于代码打包和重复发布。比如文件上传,包含了前端页面部分的展现代码和服务端处理上传文件的代码,需要处理如下几个问题:

  1. input控件的名称,因为服务端需要这个来获取$_FILES中的信息
  2. 文件如果是图像,需要判断是否是真正的图像,是否进行缩放处理,加水印等操作
  3. 文件存储位置
  4. 多文件上传的时候,服务端处理信息的返回,比如某一个文件出现异常
  5. 文件信息的存储,上传到服务器的文件,要在数据库中记录下吧,日期,路径,什么的,好管理。

还有更多别的细节,单从这5个问题来看,已经不可避免地涉及到前端展现和后端数据库了,因此用Yii扩展(Extension)的方式,无法满足实际的要求(有不同意见的同学可以留言讨论)。因此需要更加完备的载体去实现这些功能,自然考虑用模块的形式去实现。具体方法如下:

可行方案

  1. 建立一个attach模块,用以处理所有的业务
  2. 前端展现,用widget包装,放在attach模块内部,建一个widgets目录
  3. 处理上传文件,用action实现
  4. 对图像的处理,可能会用到第三方类库,在attach模块里,建一个vendor目录,存放第三方类库
  5. 数据库表初始化代码,用于创建或生成相应的文件上传记录表

目录结构如下图所示:

如此一来,这个模块就在一定程度上,可以独立发布了,其他Yii用户,只要把这个模块放到modules目录下,在配置文件里加上引用,就OK啦。

模块依赖

现实开发中,不会那么一帆风顺,总会有更多的需求进来。比如,有attach模块后,从安全方面考虑,需要确定用户是否已经登陆,以及用户的一些操作权限是否能进行文件上传操作,这个时候,势必要依赖于用户模块,关于模块依赖,Yii没有提供官方的解决方案,让大家自由发挥了。我的建议是,用声明式的解决方式,比如在模块文件里,加说明。更加强制的办法是加接口,强制调用的第三方实现。

前后台分开

通常一个应用建立的时候,会有前后台,通常做法是,整一个frontend目录和一个backend目录,区分前台和后台。但是用模块化方式开发后,为了保证模块尽可能的自描述,独立性特征,需要在模块内部区分前后台,建议的方式是分别建立两个,即前台FController和后台基础AController,其他模块内部的控制器,继承对应的控制器,这样就在模块内部,实现了前后台分离。简单小结下前后台分离所涉及的内容

  1. 用户分离,前台控制器验证的是前台用户,后台控制器验证的是后台用户信息
  2. 布局分离,前后台布局应该差别很大,所以在FController和AController两个基类里,需要分别设置不同的layout,实现布局分离
  3. …(还没想到更多,欢迎补充)

跨模块调用

跨模块调用不可避免会发生,好在Yii1.x 有个getModule方法,可以把模块初始化,并解决文件导入问题。美中不足的是,IDE的代码提示无法提示动态的模块调用,不过可以用PHPDoc方式解决,参加另一篇博文。Yii2,又增加了一个getInstance()方法,这次完美解决了代码自动提示问题,赞一个。

目录结构

这样一来,目录结构会变成这样:

各个功能都各自尽量在模块内部解决问题。

时间: 2024-07-29 03:06:30

Yii2 Day4: 模块化开发的相关文章

2.精通前端系列技术之JavaScript模块化开发

在使用seajs模块化开发之前,直接在页面引用js会容易出现冲突及依赖相关的问题,具体问题如下 问题1:多人开发脚本的时候容易产生冲突(比如全局参数冲突,方法名冲突),可以使用命名空间降低冲突,不能完全避免冲突 // JavaScript Document /*var a = 10; function tab(){} function drag(){} function dialog(){}*/ var miaov = {}; //名字比较长 , 只能降低冲突,不能完全避免 miaov.a =

UC前端‘搭积木’的模块化开发——scrat.js

模块化开发 将模块所需的js\css\img\tmpl维护在一起,一个模块一个目录 js渲染模板 css只关心模块内样式 开发团队心声:"我们希望每次研发新产品不是从零开始,不同团队不同项目之间能有可复用的模块沉淀下来." 模块生态 每个工程有_工程模块_和_生态模块_. 生态模块:基于_component规范_开发,部署到Github上,可以通过命令行工具将Github上的模块安装到工程中使用.比如:jQuery, iscroll, zepto.js, vue.js 安装命令: sc

关于Egret模块化开发---vip系统

关于Egret模块化开发---vip系统 目录 关于Egret模块化开发---vip系统... 1 前言... 1 一,搭建界面... 1 二,建立数据模型... 3 1)数据模型的搭建: 3 2)数据的建立... 4 3)数据的增删改查... 7 三.做交互, 7 结束... 8 前言 做游戏就是做数据,数据模型的设计,是体验mvc一种基础的设计,用数据驱动界面变化.. 做为一个程序要学会模块化,配置化,脚本化的需求,提防策划的需求变更的可能 例如:做一个VIP系统步骤: 搭建界面 建立数据模

javascript模块化开发编程

随着网站的不断迭代更新,js代码越来越多,那么问题来了 代码比较乱 命名出现冲突 文件依赖比较繁杂 为了解决以上问题,模块化开发出现了 1.一个简单的demo,维护和扩展模块 模块的维护和扩展一定要遵守一个约定:开闭原则 对添加开放,对修改封闭 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>扩展和维护模块</

前端模块化开发的价值

本文发表在<程序员>杂志 2013 年 3 月刊,推荐购买. 前端模块化开发的价值 随着互联网的飞速发展,前端开发越来越复杂.本文将从实际项目中遇到的问题出发,讲述模块化能解决哪些问题,以及如何使用 Sea.js 进行前端的模块化开发. 恼人的命名冲突 我们从一个简单的习惯出发.我做项目时,常常会将一些通用的.底层的功能抽象出来,独立成一个个函数,比如 function each(arr) { // 实现代码 } function log(str) { // 实现代码 } 并像模像样地把这些函

轻轻谈一下seaJs——模块化开发的利器

"仅做一件事,做好一件事." 这个应该就是seaJs的精髓了. 我在自己的一些项目中使用过seaJs,对其算是了解一二,现在就班门弄斧,轻轻地谈一下. 首先上一段度娘的话: "seaJs是一个遵循CommonJs规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制.与jQuery等JavaScript框架不同,SeaJS不会扩展封装语言特性,而只是实现JavaScript的模块化及按模块加载.SeaJS的主要目的是令JavaScript开

Javascript模块化开发 – AMD规范

通行的Javascript模块规范共有两种:CommonJS和AMD. 2009年,美国程序员Ryan Dahl创造了node.js项目,将javascript语言用于服务器端编程.这标志"Javascript模块化编程"正式诞生.因为老实说,在浏览器环境下,没有模块也不是特别大的问题,毕竟网页程序的复杂性有限:但是在服务器端,一定要有模块,与操作系统和其他应用程序互动,否则根本没法编程. node.js的模块系统,就是参照CommonJS规范实现的.在CommonJS中,有一个全局性

Yii2.0中文开发向导——高级应用程序模板

高级应用程序模板这个模板用在大型的团队开发项目中,而且后台从前台独立分离出来以便于部署在多个服务器中.由于YIi2.0的一些新的特性,这个程序模板的功能要更深一点.提供了基本的数据库的支持,注册.密码找回等功能.安装可以通过Composer来安装如果没有安装Composer,先安装 curl -s http://getcomposer.org/installer | php 然后用如下命令来获取 php composer.phar create-project --prefer-dist --s

软件开发中,什么是模块化开发?

软件产品可以被看作是由一系列具有特定功能的组件组成,作为一个完整的系统也可以被分解成一系列功能模块,这些模块之间的相互作用就形成了系统的所有功能. 所谓模块是指可组成系统的.具有某种确定独立功能的半自律性的子系统,可以通过标准的界面和其他同样的子系统按照一定的规则相互联系而构成的更加复杂的系统.每个模块的研发和改进都独立于其他模块的研发和改进,每个模块所特有的信息处理过程都被包含在模块的内部,如同一个"黑箱",但是有一个或数个通用的标准界面与系统或其他模块相互连接. 在软件的模块化开发