`) can have child elements. These elements can be strings or other HTML5 element objects.
```php
$label = html('span', 'Website!');
$link = html('a', $label);
$link->href = 'http://example.com';
echo $link; 
```
Alternatively, use the `addChild` method for any container tag.
```php
$link = html('a');
$link->href = 'http://example.com';
$link->addChild(html('span', 'Website!'));
echo $link;
```
Or `appendTo` to target a container to be added to:
```php
$link = html('a');
$link->href = 'http://example.com';
html('span', 'Website!')->appendTo($link);
echo $link;
```
All examples would output:
```html
Website! 
```
###CSS Selectors
Tag names can optionally have CSS-style class and id selectors:
```php
echo html('a#example'); //
echo html('span.small'); //
echo html('span.small.label'); //
echo html('span#example.small.label'); //
```
##API Documentation
####For self-closing elements (e.g. `
`, `
![]()
`) 
```php
html($tag, $attributes=null);
```
+	`$tag` **{string}** The name of the valid HTML5 element which can contain CSS selectors or short-hand attribute string.
+   `$attributes` **{array | string}** (optional) Collection of element attributes
Returns a `Canteen\HTML5\Node` object.
####Node Methods
+ `setAttribute($name, $value)` Set an attribute by name and value.
+ `setAttributes($values)` Set an associative array of name/value pairs.
+ `setData($name, $value)` Set data-* fields on the HTML5 element.
+ `getData($name)` Get the data-* field on the HTML5 element.
+ `appendTo(NodeContainer $container)` Add the element to the end of a container element. 
+ `prependTo(NodeContainer $container)` Add the element to the beginning of a container element.
####For container HTML elements (e.g. `
`, `
`)
```php
html($tag, $contents=null, $attributes=null);
```
+	`$tag` **{string}** The name of the valid HTML5 element which can contain CSS selectors or short-hand attribute string.
+   `$contents` **{string | Node | NodeContainer}** (optional) The string of the contents of the tag, or another element created by `html()`
+   `$attributes` **{array | string}** (optional) Collection of element attributes
Returns a `Canteen\HTML5\NodeContainer` object.
####NodeContainer Methods (extends `Node`)
+ `addChild($node)` Add a `Node` object to the bottom of the collection of nodes
+ `addChildAt($node, $index)` Add a `Node` object at a specific zero-based index
+ `removeChild($node)`  Remove a particular node from the container
+ `removeChildAt($index)` Remove a node by zero-based index
+ `removeChildren()` Remove all children from the container
+ `getChildren()`  Get the collection of all `Node` objects
+ `getChildAt($index)` Get a `Node` object at a specific index
###Additional Components
####Document
The `Document` object is used for creating a bare-bones HTML5 document.
```php
Canteen\HTML5\Document($title='', $charset='utf-8', $beautify=false);
```
+ `$title` **{string}** (optional) The title of the document
+ `$charset` **{string}** (optional) The HTML character set to use
+ `$beautify` **{boolean}** (optional) If the output should be an indented work of art.
Properties
+ `head` **{NodeContainer}** The document's `` element
+ `body` **{NodeContainer}** The document's `` element
+ `title` **{NodeContainer}** The document's `
` element
```php
	use Canteen\HTML5\Document;
	$doc = new Document('Untitled');
    $doc->head->addChild(html('script src=main.js'));
    $doc->body->addChild(html('div#frame'));
    echo $doc;
```
####SimpleList
The `SimpleList` for conveniently creating `` and `` elements.
```php
Canteen\HTML5\SimpleList($elements, $attributes=null, $type="ul");
```
+ `$elements` **{array}** The collection of strings or other HTML elements
+ `$attributes` **{array | string}** (optional) Collection of element attributes
+ `$type` **{string}** (optional) A value of either "ul" or "ol"
####Table
The `Table` object is used for creating `` elements.
```php
Canteen\HTML5\Table($data, $headers=null, $checkbox=null);
```
+ `$data` **{array}** The collection of associative-arrays with key/value pairs
+ `$headers` **{array}** (optional) The names of the header labels
+ `$checkbox` **{string}** (optional) The name of the key name in the data to replace with a checkbox, for instance "id"
```php
// Create a sample table with some rows of dummy data
$table = new Table(
    array(
        array('id'=>1, 'first'=>'James', 'last'=>'Smith'),
        array('id'=>2, 'first'=>'Mary', 'last'=>'Denver'),
        array('id'=>3, 'first'=>'Charlie', 'last'=>'Rose')
    ),
    array('ID', 'First Name', 'Last Name')
);
```
###Rebuild Documentation
This library is auto-documented using [YUIDoc](http://yui.github.io/yuidoc/). To install YUIDoc, run `sudo npm install yuidocjs`. Also, this requires the project [CanteenTheme](http://github.com/Canteen/CanteenTheme) be checked-out along-side this repository. To rebuild the docs, run the ant task from the command-line. 
```bash
ant docs
```
##License##
Copyright (c) 2013 [Matt Karl](http://github.com/bigtimebuddy)
Released under the MIT License.