资源说明:The Cake Toolkit (CTK) is a CakePHP plugin which allows you to define your View as a class, providing a powerful object-oriented factory interface to dynamically build your application's UI with configurable objects.
These tests were performed on a Intel Pentium laptop using 4 GB of RAM, with the maximum memory setting of *PHP* set to 128 MB.
**IMPORTANT:** Remember that caching is NOT enabled on this controller, as viewing the changes to the action's output is vital to the purpose of its use. Turning on the cache for an action of a **CTK** Controller is almost identical in performance to that of a standard static ".ctp" View, as the plugin uses the same routing for the cached files.
Debugging
---------
When "debug" is set to any value higher than *0*, and assuming caching is NOT enabled, the plugin will add a **Ctk-Info** header to the *HTTP* response, for example:
```
Ctk-Info: controller=Benchmark, action=single, render-time=0.019, total-memory=6.86MB, memory-usage=1.83MB
```
This header contains the following values:
* **controller:** The name of the Controller called.
* **action:** The name of the action executed.
* **render-time:** The time in seconds it took to render the View.
* **total-memory:** The total amount of memory used until rendering was complete.
* **memory-usage:** The memory consumed specifically by the plugin.
It's also possible to see the internal object model of a View by simply setting it to use the **Schema** renderer in your View class.
```php
public $renderer = 'Ctk.Schema';
```
This will output the View as an abstract XML schema of the factories and objects used, for example:
```
```
The output includes additional information about the request and response, as well as the performance statistics also present in the **Ctk-Info** header.
Apart from this, the usual *CakePHP* debugging options remain available, such as logs, the **debug()** function and the **Debugger** class.
Support
-------
For support, bugs and feature requests, please use the [issues](https://github.com/jameswatts/cake-toolkit/issues) section of this repository.
Contributing
------------
If you'd like to contribute new features, enhancements or bug fixes to the code base just follow these steps:
* Create a [GitHub](https://github.com/signup/free) account, if you don't own one already
* Then, [fork](https://help.github.com/articles/fork-a-repo) the [Cake Toolkit](https://github.com/jameswatts/cake-toolkit) repository to your account
* Create a new [branch](https://help.github.com/articles/creating-and-deleting-branches-within-your-repository) from the *develop* branch in your forked repository
* Modify the existing code, or add new code to your branch, making sure you follow the [CakePHP Coding Standards](http://book.cakephp.org/2.0/en/contributing/cakephp-coding-conventions.html)
* Modify or add [unit tests](http://book.cakephp.org/2.0/en/development/testing.html) which confirm the correct functionality of your code (requires [PHPUnit](http://www.phpunit.de/manual/current/en/installation.html) 3.5+)
* Consider using the [CakePHP Code Sniffer](https://github.com/cakephp/cakephp-codesniffer) to check the quality of your code
* When ready, make a [pull request](http://help.github.com/send-pull-requests/) to the main repository
There may be some discussion regarding your contribution to the repository before any code is merged in, so be prepared to provide feedback on your contribution if required.
A list of contributors to the **Cake Toolkit** can be found [here](https://github.com/jameswatts/cake-toolkit/contributors).
Licence
-------
Copyright 2012-2013 James Watts (CakeDC). All rights reserved.
Licensed under the MIT License. Redistributions of the source code included in this repository must retain the copyright notice found in each file.
Acknowledgements
----------------
A special thanks to [Larry Masters](https://github.com/phpnut), the founder of [CakePHP](http://cakephp.org), for his help and support, to [José Lorenzo](https://github.com/lorenzo) for his input early on when I was hacking the framework, to [Florian Krämer](https://github.com/burzum) for his constructive criticism, as well as the entire [CakeDC](http://cakedc.com) team for their feedback and encouragement.
Cake Toolkit (CTK) ================== The **Cake Toolkit** is a *CakePHP* plugin designed for medium-to-large scale web applications which require a scalable and standard solution to handling Views. The plugin allows Views to be defined as a class, providing a powerful object-oriented factory interface to dynamically build your application's UI with configurable objects. The main features of the plugin include: * **Object-Oriented Design:** Every UI element is defined and manipulated as an object, giving you maximum control over the development of your View, by limiting your work to the semantic definition of the interface. * **Abstraction and Encapsulation:** The ability to define a View as a native *PHP* class unlocks the potential of the native object-oriented features of the language, allowing Views to be extended, blocks of content to be abstracted, and view logic to be encapsulated in helper methods. * **Separation of Concerns:** The design of the plugin provides a clear and coherent separation of the languages implicated in your development, such as *PHP*, *HTML*, *CSS* and *JavaScript*, making it easy to delegate experts in their field to the relevant areas, without having to work around code they're not familiar with. * **Extensible Architecture:** Allowing collections of UI elements to be packaged into factories makes it easy to, not only extend the existing factories but, also create your own, tailored to your requirements. * **Plug and Play:** The functionality of the plugin only adds to the current features available in *CakePHP*, making it possible for **CTK** Views to work along-side normal static ".ctp" Views. * **Legacy Features:** Great care has been taken to maintaining the availability of the standard features for Views available in *CakePHP*, such as *layouts*, *elements*, *content blocks* and *helpers*. To start using the **Cake Toolkit** it's as simple as including the plugin in your application, and then extending the *CtkAppController* to inherit everything you'll need, for example: ```php class ExampleController extends CtkAppController { public function index() { // action logic } } ``` Or, alternatively, using the *AppComponent* for existing controllers, which also allows you to *ignore* specific actions to continue using normal ".ctp" views: ```php public $components = array( 'Ctk.App' => array( 'ignoreAction' => array('example') // allow "example" action to continue using "example.ctp" ) ); ``` You can then define your View as a class, and build your UI using the objects made available through the included factories, without requiring extensive knowledge of the underlying technologies, for example: ```php class IndexView extends CtkView { public $factories = array('Ctk.Html', 'Ctk.Js'); public function build() { // create a HTML div $div = $this->Html->Div(); // create a HTML button $button = $this->Html->Button(array( 'value' => __('Click Me') )); // bind an event to the button $button->bind('click', $this->Js->Alert(array( 'text' => __('Hello World') ))); // add the button to the div $div->add($button); // add the div to the view $this->add($div); } } ``` This file is saved as "IndexView.php" in a sub-directory of your View directory called ```/Ctk```. This helps maintain your class files separate from your normal ".ctp" Views. So the path to your View class would be: ``` app/View/Example/Ctk/IndexView.php ``` It's also possible to use the special *Factory* helper to import objects from the **Cake Toolkit** into normal static ".ctp" Views, bringing the power of the plugin to your existing front-end code. ```php public $helpers = array( 'Ctk.Factory' => array( 'factories' => array('Ctk.Html', 'Ctk.Css') ) ); ``` You can then use the objects within your markup, similar to when using the HTML helper, for example: ```phpFactory->Html->Span(array('text' => __('Hello World'))); ?>``` To get up and running quickly check out the [Quick Start](Docs/Tutorials/Quick-Start.md) or [Hello World](Docs/Tutorials/Hello-World.md) tutorials from the [documentation](Docs/Home.md). Requirements ------------ * CakePHP 2+ * PHP 5.3+ Documentation ------------- Once installed, the **Cake Toolkit** has a homepage built into the *CakePHP* plugin itself. To access the homepage, visit ```/ctk``` from your application base, for example: ``` http://example.com/ctk ``` Full documentation, as well as tutorials, are also available in the [Docs](Docs/Home.md) directory of this repository. Performance ----------- As with all modern web applications, performance is an important issue to take into consideration, specially if you're running a large enterprise scale application which has high development and maintenance costs associated with it. It's important to note that the aim of the **Cake Toolkit** is not to increase the performance of the View layer in the *MVC* stack, but to improve the effectiveness of the development, as well as decrease the maintenance required for large scale applications. *CakePHP* already has very powerful and configurable caching mechanisms available, which are also available to **CTK** when building your Views, and strongly recommended due to the heavy use of objects by the plugin. To quickly add caching to your View, simply define the **$cacheAction** property in your Controller, and define the settings for the actions you wish to cache. For example, with an action called "example", you can define a cache time of 1 week with the following: ```php public $cacheAction = array( 'example' => array('duration' => 36000) ); ``` Packed with the plugin is a *Benchmark* controller which provides various actions which can be scaled at runtime to view the overall performance impact: * **single:** This action simply creates a series XML nodes. It accepts a single argument, which is the number of nodes to generate. * **lineal:** This action creates a multi-dimensional sequence of XML nodes in a lineal hierarchy. It accepts a single argument, which is the number of levels of nodes to generate. * **exponential:** This action creates a multi-dimentional sequence of XML nodes in an exponential hierarchy. It accepts a single argument, which is the number of exponential factors to generate. * **matrix:** This action displays a matrix of data in a HTML table. It accepts 2 arguments, the first is the number of rows to generate, and the second the number of cells in each row. The following table shows a basic performance scalability benchmark based on the *single* action of the *Benchmark* Controller, without caching enabled:
1 Node | 10 Nodes | 100 Nodes | 1000 Nodes | 10000 Nodes | |
---|---|---|---|---|---|
Render Time | 0.019 | 0.024 | 0.030 | 0.236 | 2.386 |
Total Memory | 6.86 MB | 6.89 MB | 7.17 MB | 10.03 MB | 38.98 MB |
Memory Usage | 1.83 MB | 1.86 MB | 2.14 MB | 5.01 MB | 33.96 MB |
本源码包内暂不包含可直接显示的源代码文件,请下载源码包。