今天看啥
热点:

CodeIgniter 是一个小巧但功能强大的 PHP 框架,作为一个简单而“优雅”的工具包,它可以为 PHP 程序员建立功能完善的 Web 应用程序。如果你是一个使用共享主机,并且为客户所要求的期限而烦恼的开发人员,如果你已经厌倦了那些傻大笨粗的框架。

CodeIgniter下载和安装

下载地址:http://codeigniter.org.cn/

安装可以查看官方的视频:http://codeigniter.org.cn/tutorials

 

CodeIgniter 的基本架构

先来介绍一下 CodeIgniter 的基本架构好了, 所以先来说明一下 CI 的页面是怎么做的。由于使用 MVC 架构, 所以最主要的就是 Controller, 程式透过 Controller 来呼叫 Model 存取资料库, 然后在指定 View 输出, 这样一来, Controller 就可以变得很简单。以制作 Blog 为例, Blog 的首页通常都会显示最新的 10 篇文章, 就以这个简单的范例来说明。不过在这里先只讨论 Controller 部份。
  基本上, 每个 Controller 都是一个 Class, 在每个 Class 里面的 function 都是一个页面, 嗯, 这个概念很重要! 先来看看下面这一段, 应该就会比较清楚。
 

PHP复制代码
<?php
class Blog extends Controller{
function index(){
$this->load->model('blog_model');
$data = $this->blog_model->get_lastest_entries();

$this->load->view('blog', $data);
}

function post($id){
echo "这里是第 $id 篇文章";
}
}
?>
复制代码


在上面这段程式码, 可以看到是一个叫做 Blog 的 Class, 里面包含了 index 以及 post 两个 function。先来说明比较简单的 post 好了, 在先前有提到, 在 Class 中的 function 其实就是一个页面, 不像以往, 一个 php 档案就是一个页面。

接着来看看要如何存取 post 这个页面, 首先看到下面这个网址

http://domain/blog/post/26

这个网址在 domain 后面的部份, 一开始接的是 “blog”, 没错, 指的就是刚才上面写的 Blog Class, 接着是 “post” 就是在 Class 中看到的 post function, 再后面的 “26〃 就是要传给 post function 的 $id 变数, 也就是第 26 篇文章, 所以只要输入上面的网址, 就可以执行 Blog class 中的 post function, 而输出的结果就跟程式中看到的一样, 会直接输出一行文字, 如下:

这里是第 26 篇文章

看到这边大概就知道 CI 的 Controller 是怎么运作的吧? 好, 接着再来看看 index 这个 function, 存取 index 页面的网址如下

http://www.bkjia.com/blog/index

或更简短

http://domain/blog

只要输入上面这个网址就会显示出 index 这个 function 所产生的页面, 也就是显示最新的 10 篇 blog 文章。另外, 由于 index 是 CI 预设的首页, 所以存取这个页面的网址可以比 post 更简短, 不过这个 index function 未免也太简洁了吧!? 没错, 使用 CI 就是那么简洁

接下来来说明一下 index 里的程式码, 可以看到 index function 里总共只有 3 行, 先来看看第一行:

$this->load->model('blog_model');

在这里大家先知道, 这里是在载入一个叫做 blog_model 的 Model, 而 Model 主要的工作就是在存取资料库。接下来第二行如下:

$data = $this->blog_model->get_lastest_entries();

在这里就先想像一下 blog_model 中, 已经写好一个叫做 get_latest_entries 的 function, 会取出最新的 10 篇文章然后 return。而在上面可以看到, 最后会将取出的资料传给 $data 这个变数, 接着在最后一行, 将 $data 一起输出给 View, 这样一来就完成了 Blog 首页啦!! 当然 View 的部份也就不先说明了。不过还是列一下如和载入要显示的 View, 并先前透过 get_latest_entries 所取出的资料一起透过 View 输出。

$this->load->view('blog', $data);

基本上 Controller 就是长得这样, 在一个 Controller (Class) 中包含许多页面(function), 这么一来, 把相关的页面写在同一支 Controller 中, 是不是比较好维护呢? 另外使用 MVC 架构, Controller 看起来也会简洁许多。

 

CodeIgniter 分页教程(Pagination)

原文: http://godbit.com/article/pagination-with-code-igniter

翻译整理来自网络,帮客之家整理;
  有些时候,你可能需要把数据库查询所得到的一篇文章或一组结果拆分成多页。在这时,你将需要写某种分页脚本。这对于从没有做过这个的开发者来说还是有一点难度的,但使用 CodeIgniter却是轻而易举就能完成的。
  CodeIgniter 具有非常容易使用的分页类。在本教程中我会做一个从数据库返回一组结果并分页这些结果的简单例子。我将使用最新版本的 CI,写这篇文章时的版本是 1.5.1 。分页类并没有修改(至少我认为没有),用最新的稳定版框架总是好的。现在,让我们开始吧。


配置和数据库设置

  很好,一切正常,当我们开始写一个 CI 应用程序时,我们要设置很多东西。我们首先打开 config.php 文件(可在 /system/application/config/ 中找到)。在这里我们将输入站点根 URL。这是我的设置:

PHP复制代码
$config['base_url'] = "http://localhost/~yannick/pagination/";
复制代码

你的设置可能会和我的略有不同。
  这个应用程序将使用一个数据库,所以我们下一步的工作是创建数据库,然后再以 CI 访问我们的数据库。要做到这一点请打开 database.php,这也定位在你的 config 文件夹中,并填写必要的信息,以便连接到你的数据库。您可以下载“例子代码”:如果你愿意可以使用例子代码和我的例子数据库。这将创建一个名为“christian_books”的表,并插入一些测试数据。同时,我想你现在可以猜一猜分页后是什么样?如果你猜对了一些“Christian Books”,你将是正确的。


控制器

  我们的基本配置文件和数据库设置已经完成,现在我们需要创建一个控制器。我将它命名为“books.php”,并且它将包含下列代码:

PHP复制代码
class Books extends Controller {
function __construct() {
parent::Controller();
$this->load->helper('url');
$this->load->database();
}

function index() {
// load pagination class
$this->load->library('pagination');
$config['base_url'] = site_url('books/index');
$config['total_rows'] = $this->db->count_all('christian_books');
$config['per_page'] = 5;
$config['uri_segment'] = 3; // 表示第 3 段 URL 为当前页数,如 index.php/控制器/方法/页数,如果表示当前页的 URL 段不是第 3 段,请修改成需要的数值。

$config['full_tag_open'] = '<p>';
$config['full_tag_close'] = '</p>';

$this->pagination->initialize($config);

//load the model and get results
$this->load->model('books_model');
$data['results'] = $this->books_model->get_books($config['per_page'],$this->uri->segment(3));

// load the HTML Table Class
$this->load->library('table');
$this->table->set_heading('ID', 'Title', 'Author', 'Description');

// load the view
$this->load->view('books_view', $data);
}
}
复制代码

如果你读过我最近写的介绍 CI的系列文章,那么,你将在这里看到许多很熟悉的内容。如果你没读过并且是新手,要想感受 CI 这种自由的话,要阅读上面的这篇文章,然后再回来继续看下面的内容。如果你已经加快了学习速度,那么,让我们继续看看上述代码更详细的描述。
  首先,我们在构造函数中装载 URL 辅助函数和数据库。当然,你不一定要创建一个构造函数并装载这些辅助函数,因为它可以很容易的在控制器中的其它函数/方法中装载,但是,如果辅助函数将用于控制器中的大多数/所有方法的话,我通常倾向于创建一个构造函数并把它们放在里面。
  其次,我们创建了一个名为 index() 的方法。这是一个非常基本的应用程序,正因如此,我们将只需要这种单一的方法,使我们装载分页类,模型和 HTML 表格类(我们稍后将讨论的内容) 。
  让我们开始吧!你会看到非常简单的使用分页类的方法。首先,我们配置要分页页面的 URL:

PHP复制代码
$config['base_url'] = base_url().'index.php/books/index/';
复制代码

这个 base_url() 函数不要与 $config[] 数组中的 base_url 相混淆。该 base_url() 函数来自 URL 辅助函数并且它代表整个应用程序的 URL。在上述代码中,连接到 base_url() 后面的内容是要分页页面的地址。
  然后,我们设置数据库中的总行数:

PHP复制代码
$config['total_rows'] = $this->db->count_all('christian_books');
复制代码

这个函数返回数据库中的所有行,如果你运行一个特定查询将返回某些行,并不一定是所有的行,然后,你可能会使用在记录辅助函数中的 $query->num_row() 函数。
  $config['per_page'] 变量简单地告诉分页类每页显示多少条记录。$config['full_tag_open'] 和 $config['full_tag_close'] 变量说明使用什么标签包围分页链接。
  接下来,我们装载模型,我们将执行其中的一个方法:get_books()。它有两个参数,limit,这决定了每页显示多少项目,offset,它表示从哪行开始返回记录。你会发现,第一个参数(limit)从 $config['per_page'] 变量中取值,而第二个参数则通过 URL 辅助函数,从 URL 的第三段中取值:$this->uri->segment(3)。后者是这里非常有趣的原因。CI 的 URL 通常采取以下形式,www.your-site.com/index.php/class/function/ID,(eg:www.bkjia.com)所以大家可以看到第三段(index.php 的后面)代表 ID。所以允许采用如下的 URL:

http://localhost/~yannick/pagination/index.php/books/index/10

  URL 第三段的 10 将被插入到我们模型函数的第二个参数中:get_books(5, 10),它表示偏移量(offset)。因此,我们的结果将返回数据库中前 10 条记录的后 5 条记录(因为根据前面的代码,我们每页显示 5 条记录)。非常妙,对不对?好了,我们先在停在这里休息一下,更详细的内容将在下一节中。
  现在,这里有一些新东西。在这里,我们装载 HTML 表格类,这是新添加到 CI 1.5.0 版本中的。这个类允许你从数组或数据库结果中生成 HTML 表格。你可以进行相当多的定制,但在这个例子中,我使用他基本形式中的一种:我明确的指明表格的头部应该是什么。

PHP复制代码
$this->table->set_heading('ID', 'Title', 'Author', 'Description');
复制代码

如果我没有指明这一点,HTML 表格类将使用它们在数据库表中的名字作为表名。因此,举例来说,如果你的数据库表中有一个列名为“book_id”,则表格类将使用“book_id”。如果你不想它这样显示的话,则上述代码片断允许你指定一个更可读的字段名。
  最后,我们装载“视图”,并传递给它我们将用到的任何数据。都做好后,我们的控制器就完成了。现在,让我们来看看我们的模型,看看怎样在分页中发挥它的威力。


模型

  OK,这时候模型就开始重新调用你数据库里的信息了。在这个分页教程中,我们的模型将包含一个方法,它基于页面上的用户请求,从数据库中获取正确的结果。正如你所看到的,控制器方法有两个参数,一个 limit 和另一个 offset。然后,我们创建一个文件,命名为“books_model.php”,并在文件中输入下列代码:

PHP复制代码
class books_model extends Model {
function __construct(){
parent::Model();
}

function get_books($num, $offset) {
$query = $this->db->get('christian_books', $num, $offset);
return $query;
}
}
复制代码

大家可以看到,我们的模型‘books_model‘和方法 get_books(),本教程中包含了一个填充了图书记录的数据库,我们希望取得这些图书并显示在屏幕上。你会注意到我们调用 get_books() 的两个参数,分别是 $num 和 $offset。 $num 指明从数据库中取得的记录数,$offset 指明将从哪开始获取记录。

PHP复制代码
$query = $this->db->get('christian_books', $num, $offset);
复制代码

上面的代码将产生下面的 MySQL 查询(举例):

SQL复制代码
SELECT * FROM christian_books LIMIT 10, 5
复制代码

5 代表 $num,10 代表 $offset。以上就是传给模型的所有内容了。我们存储这些结果在一个名为 $query 的变量中,然后把变量返回给调用它的方法。把这些结合起来,我们的模型就写完了。
  我们已经完成了 2/3 了,最后事情是,我们要创建视图。


视图

  记住,一个视图就是一个简单的 Web 页面或页面片段。所以,在这里我们的视图是一个在表格里显示图书的 Web 页面。让我们来看看代码:

HTML复制代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-us" lang="en-us">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link rel="stylesheet" href='<?php echo base_url(); ?>css/main.css' type="text/css" media="screen, projection" />
<title>CodeIgniter Pagination Tutorial</title>
</head>
<body>
<h1>Christian Books</h1>
<?php echo $this->table->generate($results); ?>
<?php echo $this->pagination->create_links(); ?>
</body>
</html>
复制代码

你可能会想,“这当然不能这么简单。”是的,这只是为本教程创建的视图。

PHP复制代码
$this->table->generate($results);
复制代码

首先,把从模型中得到的结果传递到 generate() 方法中,这样,我们将创建显示图书表格的 HTML 代码。

PHP复制代码
$this->pagination->create_links();
复制代码

接下来,我们分页类中的 create_links() 方法是最有用的,它创建各页页码的链接,包括“下一页”和“上一页”的链接。它看起来类似这样:

« First < 1 2 3 4 5 > Last »

  现在访问你的页面,并在显示页码的地方开心的玩一玩。你也可以从一页切换到另一页,看看 URL 是怎样变化的,并且 URL 的第三段表示显示在表格中结果的偏移量。


总结

  好了,上面我简单介绍了分页类,正如你看到的,添加分页功能到你的 CI 应用程序并不难。我也介绍了在 1.5.0 版本中新添加的 HTML 表格类,并且它也不是很难。这个类库使我们可以快速的创建 HTML 表格,以显示我们的结果。
  就这样了,我希望你在享受本教程的同时,会发现它内容翔实并对你有帮助。如果你有兴趣学习如何在没有 CI 框架帮助的情况下,在 PHP 中做分页程序,那么,我建议你看看 Jonathan Sampson 制作的分页视频.
  世界和平,上帝保佑。

评论暂时关闭