When displaying user input in your Views, it is important to convert all characters which have significance in HTML to their "entity" representation.
For example, the < symbol should be converted to its entity representation. Converting HTML characters to their entity representation helps protect your application from cross-site scripting:
echo HTML::entities('<script>alert(\'hi\');</script>');
echo e('<script>alert(\'hi\');</script>');
echo HTML::script('js/scrollTo.js');
echo HTML::style('css/common.css');
echo HTML::style('css/common.css', array('media' => 'print'));
Further Reading:
echo HTML::link('user/profile', 'User Profile');
echo HTML::link_to_secure('user/profile', 'User Profile');
echo HTML::link('user/profile', 'User Profile', array('id' => 'profile_link'));
echo HTML::link_to_route('profile');
$url = HTML::link_to_route('profile', 'User Profile', array($username));
Further Reading:
echo HTML::link_to_action('home@index');
echo HTML::link_to_action('user@profile', 'User Profile', array($username));
echo HTML::link_to_language('fr');
echo HTML::link_to_language('fr', true);
The "mailto" method on the HTML class obfuscates the given e-mail address so it is not sniffed by bots.
echo HTML::mailto('[email protected]', 'E-Mail Me!');
echo HTML::mailto('[email protected]');
echo HTML::image('img/smile.jpg', $alt_text);
echo HTML::image('img/smile.jpg', $alt_text, array('id' => 'smile'));
echo HTML::ol(array('Get Peanut Butter', 'Get Chocolate', 'Feast'));
echo HTML::ul(array('Ubuntu', 'Snow Leopard', 'Windows'));
echo HTML::dl(array('Ubuntu' => 'An operating system by Canonical', 'Windows' => 'An operating system by Microsoft'));
It's easy to define your own custom HTML class helpers called "macros". Here's how it works. First, simply register the macro with a given name and a Closure:
HTML::macro('my_element', function()
{
    return '<article type="awesome">';
});
Now you can call your macro using its name:
echo HTML::my_element();