SlideShare a Scribd company logo
1 of 41
Общая
архитектура
Yii2
YiiSoft
Климов П.В.
Область применения
• Построение функциональности не
имеющей аналогов
• Новая интерпретация уже существующих
бизнес процессов
• Стык или объединение различных
областей и процессов
• Системы с повышенными требованиями к
качеству
Основные характеристики
• PHP 5.4
• ООП
• Модульность
• Простота
• Высокое быстродействие
Управление зависимостями
Composer
Manages PHP packages
Bower
Manages CSS and
JavaScript packages
composer-asset-plugin
Substitute Bower client,
compatible with composer
"request non-PHP package"
"use Bower protocol as client"
Автозагрузка классов
// Autoload via Composer by PSR-4 :
$model = new yiibaseModel();
// Yii built-in autoload by PSR via alias:
Yii::setAlias(‘@app’, ‘/var/www/myproject’);
$someObj = new appmodelsCustomer();
// include ‘/var/www/myproject/models/Customer.php’;
Магия в PHP
class Object
{
public $publicProperty;
private $_privateProperty;
public function setPrivateProperty($value)
{
$this->_privateProperty = $value;
}
public function getPrivateProperty()
{
return $this->_privateProperty;
}
}
class Object
{
public function __get($propertyName)
{
$methodName = 'get‘ . $propertyName;
if (method_exists($this, $methodName)) {
return call_user_func([$this, $methodName]);
} else {
throw new Exception("Missing property {$propertyName}'!");
}
}
public function __set($propertyName, $value)
{
$methodName = 'set‘ . $propertyName;
if (method_exists($this, $methodName)) {
return call_user_func([$this, $methodName], $value);
} else {
throw new Exception("Missing property {$propertyName}'!");
}
}
$object = new Object();
$object ->publicProperty = 'Public value';
echo ($object->publicProperty);
$object->privateProperty = 'Private value';
echo ($object->privateProperty);
Порождение объектов
function createObject(array $config)
{
$className = $config['class'];
if (empty($className)) {
throw new Exception(‘Missing parameter "class"!');
}
unset($config['class']);
$object = new $className();
foreach ($config as $name=>$value) {
$object->$name = $value; // Конфигурация
}
return $object;
}
$config = [
'class‘ => ‘yiiwebUrlManager',
'enablePrettyUrl‘ => true,
'showScriptName‘ => false,
'rules‘ => [
'/‘ => 'site/index',
'<controller:w+>/<id:d+>*‘ => '<controller>/view',
],
];
$object = Yii::createObject($config);
Задание любого объекта через массив:
Dependency Injection (DI)
baseComponent
diServiceLocator
$definitions
$components
*1
“Get class
instance”
ComponentA
Client
get($id)
“Request component
by id”
…
diContainer
$definitions
$dependencies
$singletons
set($class, $params)
get($class)
“Create and
store by id”
“instantiate”
diServiceLocator
baseModule
baseApplication
$config = [
'name‘ => 'My Web Application',
…
'components‘ => [
'user‘ => [
‘enableAutoLogin‘ => true,
],
…
],
];
(new yiiwebApplication($config))->run();
…
$application = Yii::$app;
$user = Yii::$app->get(‘user’);
MVC в Yii2
ComponentApplication
ControllerModule
ViewWidget AssetBundle
Model
“create”
“render” “register”
“render
part”
*1
1
*
*
1
*
*
*
*
*
1
C
V
M
*
Маршрутизация web запроса
:Application
:Request
:UrlManager
:Controller
web server
‘run’
‘handle’ ‘resolve’
‘route’
‘run action’
‘output’
‘data’
:Response‘response’
‘output’
‘compose output’
Построение отображения
class View extends Component
{
public function renderFile($viewFile, $data = null)
{
require($viewFile);
}
}
<html>
<body>
<h1>Data <?php echo $data; ?></h1>
<hr />
<?php $this->render(‘main_menu.php’); ?>
</body>
</html>
Структура отображения
ViewRenderer
View
render()
“Define specific renderer”
smartyViewRenderer
handles *.tpl
twigViewRenderer
handles *.twig
“by file extension”
1 *
ViewContextInterface
11
“determine view path”
Виджет (Widget)
<?php echo GridView::widget([
'dataProvider' => $dataProvider,
'options' => ['class' => 'detail-grid-view table-responsive'],
'filterModel' => $searchModel,
'columns' => [
'time',
'level',
'category',
'message',
],
]); ?>
Asset Management
AssetBundle
$css
$js
$depends
View
$assetBundles
*
1
“Get Asset
Bundle”
JqueryAsset
Client
registerAssetBundle()
…
AssetManager
$bundles
getBundle()
“Create,
override
and
register”
AssetConverter
convert()
“Compose
actual files”
“Depends on”
Shortcut static
method
"register()"
class YiiAsset extends AssetBundle
{
public $sourcePath = '@yii/assets';
public $js = [
'yii.js',
];
public $depends = [
'yiiwebJqueryAsset',
];
}
class JqueryAsset extends AssetBundle
{
public $sourcePath = '@bower/jquery/dist';
public $js = [
'jquery.js',
];
}
Модель
Validator
Model
…
setAttributes()
getAttributes()
validate()
“Define specific validator”
EmailValidator RangeValidator
“Create and run”
1 *
Доступ к базе данных через
PDO
PDOClient PDO Driver
PDO MySQL PDO PostgreSQL …
1 1
MySQL PostgreSQL
Абстракция базы данных
PDO
1
Connection
Schema
mysqlQueryBuilder mysqlSchema
1
…
Command
“Types, keys, etc.”
1
* 1
QueryBuilder
“Create”
1
“Use” “Use”
*1
…
1
1
“Syntax”
*
1
Select Query Shortcut
Query
BatchQueryResult
DataReader
Command
*
1
QueryBuilder
“Create and
execute” *
1
*
1
“Create”
1
“Build”
1
Iterator
Countable
Active Record
ActiveRecord
BaseActiveRecord
save()
delete()
Command
“Instantiate by
query result”
“Database
access”
1
*
1
*
Query
ActiveQuery
ActiveRelationTrait
Shortcut static
method "find()"
// Выборка записей:
$allUsers = User::find()->all();
// Вставка новой записи:
$newUser = new User();
$newUser->name = ‘new user’;
$newUser->save();
// Обновление существующей записи:
$existingUser = User::find()->where([‘name’=>‘testuser’])->one();
$existingUser->email = ‘newemail@domain.com’;
$existingUser->save();
// Отложенная загрузка отношения:
$bio = $existingUser->profile->bio;
// Жадная загрузка отношения:
$allUsers = User::find()->with(‘profile’)->all();
«Жадная» загрузка отношений
:ActiveQuery
:User
Client
‘find with
"profile"’
‘result’
‘create from
query result’
‘get "profile"
info’
:Profile
:ActiveQuery
‘relation info’
‘find where userId in set’
‘profile references’
‘bind "profile"’
NOSQL Active Record
• MongoDB
• Redis
• ElasticSearch
• Sphinx
Cross-DBMS отношения
dbActiveRecord
BaseActiveRecord
User
“Has relation”
Profile
mongodbActiveRecord
События (Events) в Yii
Component
trigger()
eventHandlers
Event
sender
data
Handler
*
*
1
1
1
*
“Raise”
“Handle”
“List of PHP callbacks”
PHP
Callback
Обработка события
‘get event
info’
:ActiveRecord
:Event
Event Handler
Client
‘save’
‘handle “beforeInsert”’
‘saving
result’
‘raise
“beforeInsert”’
‘adjust event sender’
*
‘actual data
saving’
‘sender’
function handleBeforeInsert(Event $event)
{
$sender = $event->sender;
// Изменяем состояние отправителя события:
$sender->create_date = date('Y-m-d', strtotime('NOW'));
}
$user = new User();
// Назначаем обработчик события:
$user->on(‘beforeInsert’, ‘handleBeforeInsert’);
$user->name = ‘test name’;
$user->save();
echo $user->create_date; // Вывод: ‘2015-03-21’
Проблема множественного
наследования
ActiveRecord
ArPosition
Save custom records
display order
ArFile
Bind physical file with
the db record
ArPositionFile
Position + File
Поведение (Behavior)
Component
__call()
attachBehavior()
behaviors
Behavior
getOwner()
events()
owner
1
*
Event
data
1 1
* *
“Raise” “Handle”
Расширение интерфейса
class Component
{
private $_behaviors = [ ];
public function __call($method, $arguments)
{
// Ищем недостающий метод среди поведений:
foreach ($this->_behaviors as $behavior) {
if (method_exists($behavior, $method)) {
return $behavior->$method($arguments);
}
}
throw new Exception(“Missing method {$method}”);
}
…
}
class ArBehaviorExample extends Behavior
{
public function behaviorMethod()
{
$this->owner->create_date = date('Y-m-d', strtotime('NOW'));
}
}
$user = new User();
// Добавляем поведение:
$behavior = new ArBehaviorExample();
$user->attachBehavior($behavior);
// Вызываем метод поведения:
$user->behaviorMethod();
echo $user->create_date; // Вывод: ‘2015-03-21’
Обработка событий
class ExampleBehavior extends Behavior
{
public function events()
{
return [
‘beforeInsert’ => ‘handleBeforeInsert’,
‘afterInsert’ => ‘handleAfterInsert’
];
}
public function handleBeforeSave(Event $event)
{
// Обработка события «beforeInsert»
}
…
}
Отправка электронной почты
yiiswiftmailer
yiimail
BaseMailer
*
“Send”
1
MailerInterface MessageInterface
BaseMessage
Shortcut method "send()"
Mailer Message
Расширение «AuthClient»
BaseClient
Collection
BaseOAuth OpenId
“Configure and
create”
1 *
ClientInterface
OAuth1 OAuth2
FacebookTwitter Yandex
Дополнительные расширения
• Gii
• Debug
• Boostrap
• JUI
• Codeception
• Imagine
• ApiDoc
Yii2
• Composer + Bower
• Компонентная структура и DI
• MVC
• Управление «assets»
• PDO и Active Record
• NOSQL и Active Record
• Cross-DBMS отношения
• События
• Поведения
• Стандартные расширения

More Related Content

What's hot

Yii2
Yii2Yii2
Yii2Noveo
 
Реализация шаблонов корпоративных приложений в Magento
Реализация шаблонов корпоративных приложений в MagentoРеализация шаблонов корпоративных приложений в Magento
Реализация шаблонов корпоративных приложений в MagentoMagecom Ukraine
 
DevConf 2012 - Yii, его разработка и Yii2
DevConf 2012 - Yii, его разработка и Yii2DevConf 2012 - Yii, его разработка и Yii2
DevConf 2012 - Yii, его разработка и Yii2Alexander Makarov
 
"Жизнь без интернета" Кувалдин Артём, Яндекс
"Жизнь без интернета" Кувалдин Артём, Яндекс"Жизнь без интернета" Кувалдин Артём, Яндекс
"Жизнь без интернета" Кувалдин Артём, Яндексit-people
 
UWDC 2013, Как мы используем Yii
UWDC 2013, Как мы используем YiiUWDC 2013, Как мы используем Yii
UWDC 2013, Как мы используем YiiAlexander Makarov
 
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...Industrial Programming Java - Lection Pack 01 - Building an application - Lav...
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...Fedor Lavrentyev
 
Yii 2. Что нового?
Yii 2. Что нового?Yii 2. Что нового?
Yii 2. Что нового?yiiconf
 
YiiConf 2012 - Alexander Makarov - Yii2, что нового
YiiConf 2012 - Alexander Makarov - Yii2, что новогоYiiConf 2012 - Alexander Makarov - Yii2, что нового
YiiConf 2012 - Alexander Makarov - Yii2, что новогоAlexander Makarov
 
10 - Web-технологии. MVC фреймворки (продолжение)
10 - Web-технологии. MVC фреймворки (продолжение)10 - Web-технологии. MVC фреймворки (продолжение)
10 - Web-технологии. MVC фреймворки (продолжение)Roman Brovko
 
Take more from Jquery
Take more from JqueryTake more from Jquery
Take more from JqueryMagento Dev
 
Чуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПЧуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПzfconfua
 
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...Fedor Lavrentyev
 
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)ZFConf Conference
 
Frontend весна 2014 лекция 3
Frontend весна 2014 лекция 3Frontend весна 2014 лекция 3
Frontend весна 2014 лекция 3Technopark
 
Организация работы с API на Vue.js, Виталий Копачёв
Организация работы с API на Vue.js, Виталий КопачёвОрганизация работы с API на Vue.js, Виталий Копачёв
Организация работы с API на Vue.js, Виталий КопачёвMail.ru Group
 

What's hot (20)

Yii2
Yii2Yii2
Yii2
 
Почему Mojolicious?
Почему Mojolicious?Почему Mojolicious?
Почему Mojolicious?
 
UWDC 2013, Yii2
UWDC 2013, Yii2UWDC 2013, Yii2
UWDC 2013, Yii2
 
Реализация шаблонов корпоративных приложений в Magento
Реализация шаблонов корпоративных приложений в MagentoРеализация шаблонов корпоративных приложений в Magento
Реализация шаблонов корпоративных приложений в Magento
 
DevConf 2012 - Yii, его разработка и Yii2
DevConf 2012 - Yii, его разработка и Yii2DevConf 2012 - Yii, его разработка и Yii2
DevConf 2012 - Yii, его разработка и Yii2
 
"Жизнь без интернета" Кувалдин Артём, Яндекс
"Жизнь без интернета" Кувалдин Артём, Яндекс"Жизнь без интернета" Кувалдин Артём, Яндекс
"Жизнь без интернета" Кувалдин Артём, Яндекс
 
Erlang tasty & useful stuff
Erlang tasty & useful stuffErlang tasty & useful stuff
Erlang tasty & useful stuff
 
Perl 5.10 и 5.12
Perl 5.10 и 5.12Perl 5.10 и 5.12
Perl 5.10 и 5.12
 
UWDC 2013, Как мы используем Yii
UWDC 2013, Как мы используем YiiUWDC 2013, Как мы используем Yii
UWDC 2013, Как мы используем Yii
 
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...Industrial Programming Java - Lection Pack 01 - Building an application - Lav...
Industrial Programming Java - Lection Pack 01 - Building an application - Lav...
 
Yii 2. Что нового?
Yii 2. Что нового?Yii 2. Что нового?
Yii 2. Что нового?
 
YiiConf 2012 - Alexander Makarov - Yii2, что нового
YiiConf 2012 - Alexander Makarov - Yii2, что новогоYiiConf 2012 - Alexander Makarov - Yii2, что нового
YiiConf 2012 - Alexander Makarov - Yii2, что нового
 
10 - Web-технологии. MVC фреймворки (продолжение)
10 - Web-технологии. MVC фреймворки (продолжение)10 - Web-технологии. MVC фреймворки (продолжение)
10 - Web-технологии. MVC фреймворки (продолжение)
 
Take more from Jquery
Take more from JqueryTake more from Jquery
Take more from Jquery
 
Чуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПЧуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОП
 
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...
Industrial Programming Java - Lection Pack 03 - Relational Databases - Lavren...
 
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)
ZFConf 2010: Zend Framework & MVC, Model Implementation (Part 1)
 
Laravel 4 fwdays
Laravel 4 fwdaysLaravel 4 fwdays
Laravel 4 fwdays
 
Frontend весна 2014 лекция 3
Frontend весна 2014 лекция 3Frontend весна 2014 лекция 3
Frontend весна 2014 лекция 3
 
Организация работы с API на Vue.js, Виталий Копачёв
Организация работы с API на Vue.js, Виталий КопачёвОрганизация работы с API на Vue.js, Виталий Копачёв
Организация работы с API на Vue.js, Виталий Копачёв
 

Similar to Общая архитектура Yii2

Yii: миграции и инсталляции
Yii: миграции и инсталляцииYii: миграции и инсталляции
Yii: миграции и инсталляцииPaul Klimov
 
Web internship java script
Web internship   java scriptWeb internship   java script
Web internship java scriptNoveo
 
Чуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПЧуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПKirill Chebunin
 
Современные платформы (фреймворки) разработки веб- приложений на PHP
Современные платформы (фреймворки) разработки веб- приложений на PHP Современные платформы (фреймворки) разработки веб- приложений на PHP
Современные платформы (фреймворки) разработки веб- приложений на PHP Magecom Ukraine
 
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...Dev_Party
 
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)7bits
 
Easy authcache 2 кеширование для pro родионов игорь
Easy authcache 2   кеширование для pro родионов игорьEasy authcache 2   кеширование для pro родионов игорь
Easy authcache 2 кеширование для pro родионов игорьdrupalconf
 
Behat в PHP с использованием Behat и Mink
Behat в PHP с использованием Behat и MinkBehat в PHP с использованием Behat и Mink
Behat в PHP с использованием Behat и Minktyomo4ka
 
WebCamp: Developer Day: Parse'им бэкенд - Аким Халилов
WebCamp: Developer Day: Parse'им бэкенд - Аким ХалиловWebCamp: Developer Day: Parse'им бэкенд - Аким Халилов
WebCamp: Developer Day: Parse'им бэкенд - Аким ХалиловGeeksLab Odessa
 
Микрофреймворки PHP
Микрофреймворки PHPМикрофреймворки PHP
Микрофреймворки PHPEkaterina Giganova
 
Easy authcache 2 кэширование для pro. Родионов Игорь
Easy authcache 2   кэширование для pro. Родионов ИгорьEasy authcache 2   кэширование для pro. Родионов Игорь
Easy authcache 2 кэширование для pro. Родионов ИгорьPVasili
 
Knockoutjs на примере 2ГИС-Онлайн
Knockoutjs на примере 2ГИС-ОнлайнKnockoutjs на примере 2ГИС-Онлайн
Knockoutjs на примере 2ГИС-Онлайн2ГИС Технологии
 
Паттерны быстрой разработки WPF MVVM бизнес-приложений
Паттерны быстрой разработки WPF MVVM бизнес-приложенийПаттерны быстрой разработки WPF MVVM бизнес-приложений
Паттерны быстрой разработки WPF MVVM бизнес-приложенийGoSharp
 
Web осень 2012 лекция 4
Web осень 2012 лекция 4Web осень 2012 лекция 4
Web осень 2012 лекция 4Technopark
 
Новая eCommerce платформа D7: заказы, холдинг, персональный раздел
Новая eCommerce платформа D7:  заказы, холдинг, персональный разделНовая eCommerce платформа D7:  заказы, холдинг, персональный раздел
Новая eCommerce платформа D7: заказы, холдинг, персональный раздел1С-Битрикс
 
Виталий Каторгин, Wamba
Виталий Каторгин, WambaВиталий Каторгин, Wamba
Виталий Каторгин, WambaOntico
 
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Илья
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин ИльяDUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Илья
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Ильяit-people
 
Влад Ковташ — Yap Database
Влад Ковташ — Yap DatabaseВлад Ковташ — Yap Database
Влад Ковташ — Yap DatabaseCocoaHeads
 
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...CodeFest
 

Similar to Общая архитектура Yii2 (20)

Yii: миграции и инсталляции
Yii: миграции и инсталляцииYii: миграции и инсталляции
Yii: миграции и инсталляции
 
Web internship java script
Web internship   java scriptWeb internship   java script
Web internship java script
 
Чуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОПЧуть сложнее чем Singleton: аннотации, IOC, АОП
Чуть сложнее чем Singleton: аннотации, IOC, АОП
 
Современные платформы (фреймворки) разработки веб- приложений на PHP
Современные платформы (фреймворки) разработки веб- приложений на PHP Современные платформы (фреймворки) разработки веб- приложений на PHP
Современные платформы (фреймворки) разработки веб- приложений на PHP
 
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...
Валерий Чугреев, ИСЭРТ РАН — Архитектура MVC в контексте web-разработки — про...
 
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)
Стажировка-2014, занятие 8. Обзор Sails framework (Node.js)
 
Easy authcache 2 кеширование для pro родионов игорь
Easy authcache 2   кеширование для pro родионов игорьEasy authcache 2   кеширование для pro родионов игорь
Easy authcache 2 кеширование для pro родионов игорь
 
Behat в PHP с использованием Behat и Mink
Behat в PHP с использованием Behat и MinkBehat в PHP с использованием Behat и Mink
Behat в PHP с использованием Behat и Mink
 
WebCamp: Developer Day: Parse'им бэкенд - Аким Халилов
WebCamp: Developer Day: Parse'им бэкенд - Аким ХалиловWebCamp: Developer Day: Parse'им бэкенд - Аким Халилов
WebCamp: Developer Day: Parse'им бэкенд - Аким Халилов
 
Микрофреймворки PHP
Микрофреймворки PHPМикрофреймворки PHP
Микрофреймворки PHP
 
Easy authcache 2 кэширование для pro. Родионов Игорь
Easy authcache 2   кэширование для pro. Родионов ИгорьEasy authcache 2   кэширование для pro. Родионов Игорь
Easy authcache 2 кэширование для pro. Родионов Игорь
 
Jsfwdays 2013-2
Jsfwdays 2013-2Jsfwdays 2013-2
Jsfwdays 2013-2
 
Knockoutjs на примере 2ГИС-Онлайн
Knockoutjs на примере 2ГИС-ОнлайнKnockoutjs на примере 2ГИС-Онлайн
Knockoutjs на примере 2ГИС-Онлайн
 
Паттерны быстрой разработки WPF MVVM бизнес-приложений
Паттерны быстрой разработки WPF MVVM бизнес-приложенийПаттерны быстрой разработки WPF MVVM бизнес-приложений
Паттерны быстрой разработки WPF MVVM бизнес-приложений
 
Web осень 2012 лекция 4
Web осень 2012 лекция 4Web осень 2012 лекция 4
Web осень 2012 лекция 4
 
Новая eCommerce платформа D7: заказы, холдинг, персональный раздел
Новая eCommerce платформа D7:  заказы, холдинг, персональный разделНовая eCommerce платформа D7:  заказы, холдинг, персональный раздел
Новая eCommerce платформа D7: заказы, холдинг, персональный раздел
 
Виталий Каторгин, Wamba
Виталий Каторгин, WambaВиталий Каторгин, Wamba
Виталий Каторгин, Wamba
 
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Илья
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин ИльяDUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Илья
DUMP-2013 Frontend - Knockoutjs на примере 2ГИС-Онлайн - Таратухин Илья
 
Влад Ковташ — Yap Database
Влад Ковташ — Yap DatabaseВлад Ковташ — Yap Database
Влад Ковташ — Yap Database
 
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...
CodeFest 2012. Рычков Д. — Почему перед написанием кеша вам стоит поговорить ...
 

Общая архитектура Yii2