https://github.com/nowisesys/uup-html
Object oriented HTML class library
https://github.com/nowisesys/uup-html
html php-library render
Last synced: 6 months ago
JSON representation
Object oriented HTML class library
- Host: GitHub
- URL: https://github.com/nowisesys/uup-html
- Owner: nowisesys
- License: apache-2.0
- Created: 2019-01-23T23:02:54.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-10-15T02:59:35.000Z (about 6 years ago)
- Last Synced: 2025-02-16T08:27:30.241Z (8 months ago)
- Topics: html, php-library, render
- Language: PHP
- Size: 90.8 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## UUP-HTML - Object oriented HTML class library for PHP
An object oriented PHP library for generating HTML. It consists of component,
container and utility classes making it possible to e.g. compose a form or table
without having to bother with HTM tags.### Usage
The usage pattern is to create an container object (like a form) and add child
containers and components to it. Once composed, just call output() to make it
generate the HTML code.The add methods create and return a object. This makes it easy to incremental
adding child objects and setting properties on them. Heres an simple example on
this concept for a form:```php
$options = array('opt1' => 'val1', 'opt2' => 'val2');$form = new Form('script.php');
$combo = $form->addComboBox('opt'); // Got ComboBox object in return
foreach ($options as $name => $value) {
$option = $combo->addOption($value, $name); // Get Option object in return
}$form->addSubmitButton();
$form->output(); // Output this form
```All objects can be added to another container. The output is started when calling
output() on the top container. We could do like this:```php
$paragraph = new Paragraph();
$paragraph->addElement($form); // Add form to paragraph
$paragraph->output(); // Calls output on form object implicit
```Javascript events can be attached to all objects by appending a code fragment for wanted event:
```php
$textbox = new TextBox('username');
$textbox->setEvent(Event::ON_BLUR, 'if(this.value === "") { '
. 'alert("Username can\'t be empty"); '
. 'this.focus(); '
. '}');
```A couple of prepared event handler is defined in the Event class:
```php
$textbox = new TextBox('username');
$textbox->setEvent(Event::ON_DOUBLE_CLICK, EVENT_HANDLER_CLEAR_CONTENT);
```### More
Visit the [project page](https://nowise.se/oss/uup/html) for more information.