html-object.md 2.4 KB
Newer Older
reynaldi adriantama's avatar
reynaldi adriantama committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
# HTML Object

The HTML `<object>` element is used for embedding media like Flash or QuickTime
in web pages. The object view helpers take care of embedding media with minimum
effort.

There are four initial Object helpers:

- `htmlFlash()` Generates markup for embedding Flash files.
- `htmlObject()` Generates markup for embedding a custom Object.
- `htmlPage()` Generates markup for embedding other (X)HTML pages.
- `htmlQuicktime()` Generates markup for embedding QuickTime files.

All of these helpers share a similar interface. For this reason, this
documentation will only contain examples of two of these helpers.

## Flash helper

Embedding Flash in your page using the helper only requires the resource URI.

```php
<?= $this->htmlFlash('/path/to/flash.swf'); ?>
```

This outputs the following HTML:

```html
<object data="/path/to/flash.swf"
        type="application/x-shockwave-flash"
        classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
        codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab">
</object>
```

Additionally, you can specify attributes, parameters, and content that can be
rendered along with the `<object>`. This will be demonstrated using the
`htmlObject()` helper.

## Customizing the object by passing additional arguments

The first argument in the object helpers is always required. It is the URI to
the resource you want to embed. The second argument is only required in the
`htmlObject()` helper. The other helpers already contain the correct value for
this argument. The third argument is used for passing along attributes to the
object element. It only accepts an array with key-value pairs. `classid` and
`codebase` are examples of such attributes. The fourth argument also only takes
a key-value array and uses them to create `<param>` elements. You will see an
example of this shortly. Lastly, there is the option of providing additional
content to the object. The following example utilizes all arguments.

```php
echo $this->htmlObject(
    '/path/to/file.ext',
    'mime/type',
    [
        'attr1' => 'aval1',
        'attr2' => 'aval2',
    ],
    [
        'param1' => 'pval1',
        'param2' => 'pval2',
    ],
    'some content'
);
```

This would output:

```html
<object data="/path/to/file.ext" type="mime/type"
    attr1="aval1" attr2="aval2">
    <param name="param1" value="pval1" />
    <param name="param2" value="pval2" />
    some content
</object>
```