CI的MVC实现
CI被标榜为一款简单易用的框架,经过一段时间的了解后,它的小而精给让我印象深刻.麻雀虽小五脏俱全,一个框架产品包含太多的特性,这篇文章就说说CI中是如何实现MVC的?
执行流程
根据CI手册上提供的应用程序流程图,我们可以清晰地知道,要实现基本的MVC我们所需要的知识点是有以下几点:
- 定义处理路由
- 定义处理逻辑
- 业务逻辑所需要依赖的模型/库
- 返回的视图
而其他部分CI帮我们已经建立好了或在MVC搭建完成后可再完善,接下来就分别讨论以上几个点在CI中是怎么实现的.
路由
在CI中,路由设置的很简单,它是以请求URI分段显示路由的,如何使用[URI 分段](file:///Users/will/Documents/codeigniter_user_guide/general/urls.html)在手册中已经说明的很清楚了,这里就来说说它的源代码是如何实现的.
CI的核心源代码并没有用大量的面向对象来完成,所以我们沿着一条主线(上面的流程)跟下去,就都可以找到各个部分在哪,以及它是如何完成的.整个框架的处理逻辑是system/core/CodeIgniter.php
.路由的处理则在其308行引入了Router
.其中最重要的是\CI_Router::_set_request
这里就清晰地展示了类与方法是如何得到的.
Controller
由路由解析后,就可以找到相应的Controller,处理过程确实是简便的.这里的处理逻辑是依据不同的业务而来,代码各不相同,这里就说说Controler中遇到的问题,在CI中如何解决的.在此之前还是现看看手册--控制器.
1.调用模型
在\CI_Controller::__construct
中$this->load
(system/core/Loader.php
)就是在Controller中所需的载入方法,它包含了所有可能用到的方法.所以,载入模型就这样使用:
$this->load->model('model_name');
而其他的,需与其他类或方法进行通信的函数都是可通过$this->load完成,当然了,要让使用起来得心应手还得熟悉system/core/Loader.php
的代码.
2.传递至View
毫无疑问,这一点也是通过$this->load完成的
$this->load->view('name');
如何使用就不啰嗦了,请看手册
其实,到这里,我们应该可以体会到CI的确很简单,源代码的学习也不难.
Model
模型这一层只与Controller交互,调用的方法上文也提到了,这里不再赘述.在官方示例中:
$this->load->model('blog');
$data['query'] = $this->blog->get_last_ten_entries();
当使用load载入一个Modle后, 可直接使用$this->blog
来获取该Model,为什么?
在\CI_Loader::model
中,每载入一个模型都会成为Controller的一个属性,$CI的来源则是system/core/CodeIgniter.php::get_instance
获取到了当前Controller
$this->_ci_models[] = $name;
$CI->$name = new $model();
return $this;
View
视图是的组件,但CI中并没有使用模板引擎,原因是让视图尽可能快的生成.这一层是由Controller输出的.那么Controller是如何与View进行交互的?
首先得建立视图文件,因为不需要编译,该视图只能是html与php代码的混合.然后Controller再调用.调用的过程就是$this->load->view('view')
来完成,核心步骤则是\CI_Loader::_ci_load
,其中一个难点在于,在不使用模板引擎却需要引用多个视图文件时,怎么办?这里在核心方法中就用ob_start()
来解决,所以在视图中使用多个视图文件是可行的.
$this->load->view('header');
$this->load->view('menu');
$this->load->view('content', $data);
$this->load->view('footer');
总结
其实在查看CI的源代码后,有两点感受,手册非常简明,我们所能做的事在手册上基本上都得到了;源代码并不没有大量使用面向对象,在熟悉了这种代码风格后,源代码确实不属于非常复杂.这是一款小巧的框架;
#CI的MVC实现的更多相关文章
-
【军哥谈CI框架】之入门教程之第二讲:分析CI结构和CI是怎么工作的
[军哥谈CI框架]之入门教程之第二讲:分析CI结构和CI是怎么工作的 之入门教程之第二讲:分析CI结构和CI是如何工作的大家好!上一节,我们共同部署了一个CI网站,做到这一点非常简单,但是,亲们, ...
-
CI(CodeIgniter)学习第二讲
一.CI的文件结构: 了解CI的文件结构可以帮助我们快速的对CI框架有一个整体的认识,就好像我们去了一个陌生的城市一样,对你来讲周围的一切都是陌生和未知的,要想快速的了解这座城市,你可以买一张这座城市 ...
-
CI(CodeIgniter)学习第一讲
一.CI的优势一. (1).CI是一个PHP框架:大家都知道PHP框架有很多,CI只是其中之一,框架是为了重用发明的.同样,CI的目标是实现让你比从零开始编写代码更快速地开发项目.CI可以将需要完成的 ...
-
**[权限控制] 利用CI钩子实现权限认证
http://codeigniter.org.cn/forums/thread-10877-1-1.html 一直没找到CI的权限认证扩展,以前好像找到过一个老外的扩展,不过不怎么好用,现在记不清了, ...
-
第三方登录(QQ登录)开发流程详解
原文:http://www.cnblogs.com/it-cen/p/4338202.html 近排由于工作的繁忙,已经一个星期没写博文做分享了,接下来我对网站接入第三方登录----QQ登录的实现逻辑 ...
-
(转)第三方登录(QQ登录)开发流程详解
近排由于工作的繁忙,已经一个星期没写博文做分享了,接下来我对网站接入第三方登录----QQ登录的实现逻辑做一个详细的讲解. 对于整个流程的详细文档可以到QQ互联官网(http://wiki.conne ...
-
Codeigniter-实现权限认证
两种方法 钩子函数 集成核心Controller 方法一,钩子函数: 一直没找到CI的权限认证扩展,以前好像找到过一个老外的扩展,不过不怎么好用,现在记不清了,后来仿着jsp firter的方式用CI ...
-
使用 CodeIgniter 框架快速开发 PHP 应用(五)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(五) 简化 HTML 页面和表格设计这一章介绍了又一个节约你的时间而且使你的代码更具安全性和逻辑性的领域.第一,我们将会介绍创建视图的各 ...
-
使用 CodeIgniter 框架快速开发 PHP 应用(三)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...
随机推荐
-
LruCache算法原理及实现
LruCache算法原理及实现 LruCache算法原理 LRU为Least Recently Used的缩写,意思也就是近期最少使用算法.LruCache将LinkedHashMap的顺序设置为LR ...
-
.NET 接口
接口 接口是一组抽象成员的集合,表示某个类或结构可以选择去实现的行为,描述的是可属于任何类或结构的一组相关功能.接口方法的实现是在实现接口的类中完成的,实现接口的类可以显式实现该接口的成员, ...
-
OPENSSL 学习整理-介绍
Openssl目录名以及功能描述 目录名 功能描述 Crypto 存放OpenSSL 所有加密算法源码文件和相关标注如X.509 源码文件,是OpenSSL中最重要的目录,包含了OpenSSL 密码算 ...
-
webservice 生成代理类
webservice的调用方式有两种: 1. 直接在vs ide中通过web引用的方式,将发布于某个位置的web服务引进到工程里面.这种方式基本上会用vs.net的人都会. 2. 通过vs 命令提 ...
-
linux杂记(三)linux指令介绍
[root@linux ~]# command [-options] parameter1 parameter2 说明: 最左边的root显示的是[目前使用者的账号],而@之后接的是linux即[主机 ...
-
iOS面试题01-多线程网络
1.面试题方向: 1>.多线程+网络 2>.项目(简历上的项目,每一个细节:技术实现细节.业务.项目周期.人数) 3>.性能优化:图片优化.内存优化(tableView的循环利用) ...
-
异步加载AsyncTask
private void huodeshuju() { new AsyncTask<String, Void, String>() { @Overrid ...
-
php session 生命周期代码实例
php session 生命周期代码实例 我们为什么需要Session,就是因为我们需要存储各个用户的状态数据.那么试问,如果由你来设计解决这个需求的方案,那么也许你会设置这样一个数据 ...
-
iOS Button 上文字图片位置的设置
1. 添加图片+文字/文字+图片 ,不分前后,图片默认在文字前边 加空格隔开 UIButton * button =[[UIButton alloc] initWithFrame:CGRectMake ...
-
babel7-按需加载polyfill
babel7 babel7发布了. 在升级到 Babel 7 时需要注意几个重大变化: 移除对 Node.js 6 之前版本的支持: 使用带有作用域的 @babel 命名空间,以防止与官方 Babel ...