CakePHP с нуля: маленькое приложение. Часть 3 из 10

В предыдущем уроке мы рассмотрели базовый принцип функционирования рабочей среды CakePHP.

Построим какое-нибудь рабочее приложение. Это будет маленькое приложение с одной таблицей, которое мы будем использовать в следующих уроках и расширим до вполне функционального проекта. В конечном итоге мы построим приложение для представления данных о вакансиях с регистрацией, входом в систему, добавлением вакансии, принятием вакансии и так далее.

Нам понадобится соединение с базой данных. В первом уроке было описано, как его установить.

В данном уроке мы построим архитектуру MVC для таблицы категорий. Для лучшего представления CakePHP модель, контроллер и виды будут создаваться в уроке вручную. Да, есть другой способ. И он будет представлен в конце урока.

Создаем таблицу в базе данных:

CREATE TABLE `categories` (
  `id` INTEGER(11) NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM

Для использования философии MVC создадим модель для данной таблицы. Модели CakePHP располагаются в папке /app/models. Создаем файл category.php в папке /app/models и копируем туда следующий код. Обратите внимание на название класса, файла и таблицы. Они выбираются исходя из соглашения об именах (для имени таблицы используется множественное число) и должны соответствовать друг другу для того, чтобы в дальнейшем код было легко обслуживать.

<?php
class Category extends AppModel {
    var $name = 'Category';
}
?>

Пока это все, что нужно для модели. Соглашение о именовании предполагает, что для имени класса и файла будет использоваться единственное число. В коде просто расширяем класс CakePHP AppModel и объявляется переменная $name, которая будет использоваться контроллером для доступа к функциям модели.

CakePHP хранит контроллеры в папке /app/controllers. Создаем файл с именем categories_controller.php в папке /app/controllers и копируем в в него код:

<?php
class CategoriesController extends AppController {

	var $name = 'Categories';

	function index() {
		$this->set('categories', $this->Category->find('all'));
	}
}
?>

Код для контроллера несколько длиннее. Мы расширяем класс AppController и объявляем переменную $name. Также мы добавили функцию index. Функции контроллера называются action (действия).

Рассмотрим действия более подробно. Определяя функцию index() в нашем классе CategoriesController, мы даем пользователю доступ к адресу www.example.com/categories/index.  

Рассмотрим строку с this в функции index():

$this->set('categories', $this->Category->find('all'));

С помощью одной строки кода мы выбираем все категории из таблицы и массив результатов в переменную categories. Данная переменная будет доступна в виде.

Файлы видов CakePHP хранятся в папке /app/views в подпапке с именем соответствующего контроллера (нам нужно создать папку с именем categories в нашем случае). Создаем файл index.ctp в папке /app/views/categories. Ctp файл - это файл шаблона CakePHP. Копируем в него код:

<!-- File: /app/views/categories/index.ctp -->

<h1>Категории</h1>
<table>
    <tr>
        <th>Id</th>
        <th>Название</th>
    </tr>

    <?php foreach ($categories as $category): ?>
    <tr>
        <td><?php echo $category['Category']['id']; ?></td>
        <td>
            <?php echo $html->link($category['Category']['name'],
array('controller' => 'categories', 'action' => 'view', $category['Category']['id'])); ?>
        </td>
    </tr>
    <?php endforeach; ?>

</table>

Как вы видите, index.ctp представляет собой смешанный файл с HTML и PHP кодом. Мы добавили все категории в переменную categories, поэтому можно использовать ее в цикле foreach. Здесь просто записываются данные в таблицу HTML. Для проверки того,что получилось нужно перейти на адрес URL установки  CakePHP и добавить к нему /categories (например, http://localhost/cake/categories). Вы увидите данные в таблице.

Для генерации ссылки используется объект $html. Этот момент будет объяснен позже. Данный код генерирует ссылку на /categories/view/category_id . В нашем примере она не используется, но может представлять интерес при разработке кода MVC для таблицы статей.

Теперь изменим наш файл categories_controller.php:

class CategoriesController extends AppController {

    var $name = 'Categories';

    function index() {
        $this->set('categories', $this->Category->find('all'));
    }

    function add() {
        if (!empty($this->data)) {
            if ($this->Category->save($this->data)) {
                $this->Session->setFlash('Ваша категория сохранена.');
                $this->redirect(array('action' => 'index'));
            }
        }
    }
}

Мы добавили функцию add(). Данная функция сохраняет данные в таблице categories. Выполняется проверка наличия значения в переменной. Данная переменная используется для хранения данных переданных из формы. Затем функция сохраняет данные, выводит сообщение и перенаправляет логику приложения обратно к функции index.

Создаем вид для нашего функционала (имя файла указано в первой строке):

<!-- File: /app/views/categories/add.ctp -->    

<h1>Добавить категорию</h1>
<?php
echo $form->create('Category');
echo $form->input('name');
echo $form->end('Сохранить');
?>

Мы используем функционал CakePHP для создания формы. Если открыть данный вид с помощью браузера, использовав адрес действия (например,  http://localhost/cake/categories/add ). То вы увидите готовую к работе форму. Если посмотреть на сгенерированный код, то вы увидидте, что CakePHP автоматически трансформировал  вид в правильную форму.

Если функция create() будет вызвана без параметра, то это подразумевает, что вы строите форму, которая будет передавать данные текущему контроллеру действия  add() (или edit()) через POST.

Метод $form->input() используется для создания элемента формы для поля ввода. Первый параметр сообщает, какому он полю соответствует. Второй параметр позволяет задавать широкий диапазон опций, например, количество строк для текстового поля. Метод input() выводит различные элементы формы в зависимости от заданных поле модели.

Метод $form->end() генерирует кнопку отправки формы и завершает форму. Если задана строка в качестве первого параметра, то выводится кнопка с соответствующим именем перед закрывающим тегом формы.

Теперь изменим вид /app/views/categories/index.ctp view для включения ссылки "Добавить категорию", чтобы иметь доступ к нашим новым функциям. Сразу после

<h1>Категория</h1>

добавляем:

<?php echo $html->link('Добавить категорию',array('controller' => 'categories', 'action' => 'add')); ?>

В следующем уроке мы добавим проверку данных, редактирование и удаление.

CakePHP имеет автоматический генератор кода MVC в соответствии со схемой базы данных! Но о нем речь пойдет в других уроках.

Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/TogxlUVZE3M/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

CakePHP с нуля: маленькое приложение. Часть 3 из 10 | | 2012-06-19 12:10:25 | | Статьи Web-мастеру | | В предыдущем уроке мы рассмотрели базовый принцип функционирования рабочей среды CakePHP.Построим какое-нибудь рабочее приложение. Это будет маленькое приложение с одной таблицей, которое мы будем | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: