<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>David Rojas &#187; Desarrollo Web</title>
	<atom:link href="http://www.davidrojas.net/index.php/category/desarrollo-web/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.davidrojas.net</link>
	<description>Diseño y desarrollo web</description>
	<lastBuildDate>Fri, 23 Jul 2010 21:31:56 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Videotutorial &#8211; Patrones de diseño en PHP &#8211; Chain-of-command</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-chain-of-command/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-chain-of-command/#comments</comments>
		<pubDate>Fri, 23 Jul 2010 21:31:56 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=831</guid>
		<description><![CDATA[Para terminar la serie de screencasts sobre patrones de diseño en PHP, os enseñaré en qué consiste el chain-of-command pattern (cadena de mando), también llamado patrón cadena de responsabilidad. En él creamos una serie de objetos receptores y un objeto emisor que les envía una petición, estableciendo una cadena en la que el comando de [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/screencast_php_patterns.png" alt="" title="screencast_php_patterns" width="163" height="104" class="derecha alignright size-full wp-image-774" />Para terminar la serie de screencasts sobre patrones de diseño en PHP, os enseñaré en qué consiste el chain-of-command pattern (cadena de mando), también llamado patrón <em>cadena de responsabilidad</em>. En él creamos una serie de objetos receptores y un objeto emisor que les envía una petición, estableciendo una cadena en la que el comando de petición recorre todos los posibles objetos receptores hasta que uno de ellos responde ejecutando el comando.</p>
<p>De esta manera el emisor no tiene conocimiento de qué receptor va a ejecutar el comando, favoreciendo el <a href="http://en.wikipedia.org/wiki/Loose_coupling" title="Loose coupling">acoplamiento débil</a>.<br />
<span id="more-831"></span></p>
<h3>Ver screencast (duración: 8:05)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgfCvXw" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-11PatronesDeDiseoEnPHPChainofcommandPattern502.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (14 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-11PatronesDeDiseoEnPHPChainofcommandPattern252.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (9 MB)</a></li>
</ul>
<p></p>
<p>Podéis ver el resto de videotutoriales en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño y desarrollo web, codeigniter, PHP, CSS3">página de screencasts</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.</p>
<h3>Ejemplo de implementación</h3>
<p>Primero creamos el interfaz que implementarán los objetos receptores, seguido de la clase emisora <em>CommandChain</em>, que será la encargada de mantener la lista de instancias de los objetos receptores y pasarles las peticiones a éstos.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000000; font-weight: bold;">interface</span> ICommand<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">function</span> onCommand<span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">,</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> CommandChain<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000088;">$_commands</span> <span style="color: #339933;">=</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> addCommand<span style="color: #009900;">&#40;</span><span style="color: #000088;">$cmd</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span>_commands<span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$cmd</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> runCommand<span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">,</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">foreach</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span>_commands <span style="color: #b1b100;">as</span> <span style="color: #000088;">$cmd</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
			<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cmd</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">onCommand</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">,</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #b1b100;">return</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>A continuación creamos las clases de los objetos receptores <em>SMSCommand</em> y <em>MailCommand</em>, que implementan el interfaz <em>ICommand</em>.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">class</span> SMSCommand implements ICommand<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> onCommand<span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">,</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">!=</span><span style="color: #0000ff;">'NotifyUser'</span> <span style="color: #339933;">||</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'metodo'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">!=</span><span style="color: #0000ff;">'sms'</span><span style="color: #009900;">&#41;</span> <span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">echo</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;SMSCommand ejecutando <span style="color: #006699; font-weight: bold;">$comando</span>. Notificando usuario &quot;</span><span style="color: #339933;">.</span><span style="color: #000088;">$args</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'user'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">.</span> <span style="color: #0000ff;">&quot; via SMS.<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> MailCommand implements ICommand<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> onCommand<span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">,</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$comando</span><span style="color: #339933;">!=</span><span style="color: #0000ff;">'NotifyUser'</span> <span style="color: #339933;">||</span> <span style="color: #000088;">$args</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'metodo'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">!=</span><span style="color: #0000ff;">'mail'</span><span style="color: #009900;">&#41;</span> <span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">echo</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;SMSCommand ejecutando <span style="color: #006699; font-weight: bold;">$comando</span>. Notificando usuario &quot;</span><span style="color: #339933;">.</span><span style="color: #000088;">$args</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'user'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">.</span> <span style="color: #0000ff;">&quot; via Email.<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Finalmente, para utilizarlo instanciamos el gestor <em>CommandChain</em> y le añadimos los objetos receptores, para después llamar a su método <em>runCommand</em> que enviará el comando a dichos objetos y sólo uno de ellos responderá dependiendo de un criterio, en este caso del argumento <em>metodo</em>.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$c</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> CommandChain<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$c</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addCommand</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> SMSCommand<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$c</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addCommand</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> MailCommand<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$c</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">runCommand</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'NotifyUser'</span><span style="color: #339933;">,</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'metodo'</span> <span style="color: #339933;">=&gt;</span> <span style="color: #0000ff;">'mail'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'user'</span> <span style="color: #339933;">=&gt;</span> <span style="color: #0000ff;">'test'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p></p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;title=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command&amp;bodytext=Para%20terminar%20la%20serie%20de%20screencasts%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%2C%20os%20ense%C3%B1ar%C3%A9%20en%20qu%C3%A9%20consiste%20el%20chain-of-command%20pattern%20%28cadena%20de%20mando%29%2C%20tambi%C3%A9n%20llamado%20patr%C3%B3n%20cadena%20de%20responsabilidad.%20En%20%C3%A9l%20creamos%20una%20serie%20de%20objetos%20receptores%20y" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;title=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command&amp;notes=Para%20terminar%20la%20serie%20de%20screencasts%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%2C%20os%20ense%C3%B1ar%C3%A9%20en%20qu%C3%A9%20consiste%20el%20chain-of-command%20pattern%20%28cadena%20de%20mando%29%2C%20tambi%C3%A9n%20llamado%20patr%C3%B3n%20cadena%20de%20responsabilidad.%20En%20%C3%A9l%20creamos%20una%20serie%20de%20objetos%20receptores%20y" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;t=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;title=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command&amp;annotation=Para%20terminar%20la%20serie%20de%20screencasts%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%2C%20os%20ense%C3%B1ar%C3%A9%20en%20qu%C3%A9%20consiste%20el%20chain-of-command%20pattern%20%28cadena%20de%20mando%29%2C%20tambi%C3%A9n%20llamado%20patr%C3%B3n%20cadena%20de%20responsabilidad.%20En%20%C3%A9l%20creamos%20una%20serie%20de%20objetos%20receptores%20y" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;title=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F&amp;t=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command&amp;s=Para%20terminar%20la%20serie%20de%20screencasts%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%2C%20os%20ense%C3%B1ar%C3%A9%20en%20qu%C3%A9%20consiste%20el%20chain-of-command%20pattern%20%28cadena%20de%20mando%29%2C%20tambi%C3%A9n%20llamado%20patr%C3%B3n%20cadena%20de%20responsabilidad.%20En%20%C3%A9l%20creamos%20una%20serie%20de%20objetos%20receptores%20y" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%20-%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Chain-of-command%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-chain-of-command%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-chain-of-command/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP &#8211; Observer Pattern</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-observer-pattern/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-observer-pattern/#comments</comments>
		<pubDate>Mon, 03 May 2010 09:21:24 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=804</guid>
		<description><![CDATA[En este screencast voy a explicaros el patrón de diseño Observer (observador) en PHP, que consiste en crear objetos observables que mantienen una lista de observadores y les notifica a éstos de cualquier cambio en su estado, normalmente llamando a uno de sus métodos. Este patrón suele utilizarse para implementar un sistema de manejo de [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/screencast_php_patterns.png" alt="" title="screencast_php_patterns" width="163" height="104" class="derecha alignright size-full wp-image-774" />En este screencast voy a explicaros el patrón de diseño <em>Observer</em> (observador) en PHP, que consiste en crear objetos observables que mantienen una lista de observadores y les notifica a éstos de cualquier cambio en su estado, normalmente llamando a uno de sus métodos. Este patrón suele utilizarse para implementar un sistema de manejo de eventos distribuido, por ejemplo construir un sistema de logging en el que registramos el observador (clase que se ocupa de escribir el log) en cada objeto que queramos que envíe mensajes al log.<br />
<span id="more-804"></span></p>
<h3>Ver screencast (duración: 12:09)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgduLFQA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-10PatronesDeDiseoEnPHPObserverPattern958.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (22 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-10PatronesDeDiseoEnPHPObserverPattern678.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (16 MB)</a></li>
</ul>
<p></p>
<p>Podéis ver el resto de screencasts en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño y desarrollo web, codeigniter, PHP, CSS3">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>. Os recomiendo especialmente que no os perdáis los tutoriales de dos de los patrones más usados: el <a href="http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-singleton-pattern/">Singleton</a> y el <a href="http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-factory-pattern/">Factory Pattern</a>.</p>
<h3>Ejemplo de implementación</h3>
<p>En primer lugar creamos la clase abstracta de la que heredarán las clases observables, y el interfaz que implementarán los observadores.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
abstract <span style="color: #000000; font-weight: bold;">class</span> Observable<span style="color: #009900;">&#123;</span>
	protected <span style="color: #000088;">$observers</span><span style="color: #339933;">;</span>
	<span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span> <span style="color: #339933;">=</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> registrarObserver<span style="color: #009900;">&#40;</span><span style="color: #000088;">$observer</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #990000;">in_array</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$observer</span><span style="color: #339933;">,</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		    <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span><span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$observer</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> deregistrarObserver<span style="color: #009900;">&#40;</span><span style="color: #000088;">$observer</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #990000;">in_array</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$observer</span><span style="color: #339933;">,</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		    <span style="color: #000088;">$key</span> <span style="color: #339933;">=</span> <span style="color: #990000;">array_search</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$observer</span><span style="color: #339933;">,</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		    <span style="color: #990000;">unset</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	abstract <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> notificarObservers<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">interface</span> Observer<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> notificar<span style="color: #009900;">&#40;</span><span style="color: #000088;">$sender</span><span style="color: #339933;">,</span> <span style="color: #000088;">$params</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>

<p>A continuación creamos las clases específicas, en este caso una clase observable y dos clases de logging que actuarán de observadores.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000000; font-weight: bold;">class</span> MiObservable <span style="color: #000000; font-weight: bold;">extends</span> Observable<span style="color: #009900;">&#123;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		parent<span style="color: #339933;">::</span>__construct<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> notificarObservers<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">observers</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$observer</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
			<span style="color: #000088;">$observer</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">notificar</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$this</span><span style="color: #339933;">,</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">param</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> Evento<span style="color: #009900;">&#40;</span><span style="color: #000088;">$texto</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">param</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$texto</span><span style="color: #339933;">;</span>
		<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">notificarObservers</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> <span style="color: #990000;">Log</span> implements Observer<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> notificar<span style="color: #009900;">&#40;</span><span style="color: #000088;">$sender</span><span style="color: #339933;">,</span> <span style="color: #000088;">$param</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">echo</span> <span style="color: #990000;">get_class</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sender</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">&quot; envio <span style="color: #006699; font-weight: bold;">$param</span> a las &quot;</span><span style="color: #339933;">.</span><span style="color: #990000;">date</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'h:i:s'</span><span style="color: #339933;">,</span> <span style="color: #990000;">time</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">&quot;&lt;br /&gt;&quot;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> SalvarLog implements Observer<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> notificar<span style="color: #009900;">&#40;</span><span style="color: #000088;">$sender</span><span style="color: #339933;">,</span> <span style="color: #000088;">$param</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">echo</span> <span style="color: #0000ff;">&quot;Guardando en BD <span style="color: #006699; font-weight: bold;">$param</span> enviado por &quot;</span><span style="color: #339933;">.</span><span style="color: #990000;">get_class</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sender</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">&quot;... &lt;br /&gt;&lt;br /&gt;&quot;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>

<p>Para utilizarlo, instanciaremos las clases y registraremos los observadores de esta manera:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000088;">$obj</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MiObservable<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">registrarObserver</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> <span style="color: #990000;">Log</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">registrarObserver</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> SalvarLog<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">Evento</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Test 1'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">sleep</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">Evento</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Test 2'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">deregistrarObserver</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> SalvarLog<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">Evento</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Test 3'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>

<p></p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern&amp;bodytext=En%20este%20screencast%20voy%20a%20explicaros%20el%20patr%C3%B3n%20de%20dise%C3%B1o%20Observer%20%28observador%29%20en%20PHP%2C%20que%20consiste%20en%20crear%20objetos%20observables%20que%20mantienen%20una%20lista%20de%20observadores%20y%20les%20notifica%20a%20%C3%A9stos%20de%20cualquier%20cambio%20en%20su%20estado%2C%20normalmente%20llamando%20a" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern&amp;notes=En%20este%20screencast%20voy%20a%20explicaros%20el%20patr%C3%B3n%20de%20dise%C3%B1o%20Observer%20%28observador%29%20en%20PHP%2C%20que%20consiste%20en%20crear%20objetos%20observables%20que%20mantienen%20una%20lista%20de%20observadores%20y%20les%20notifica%20a%20%C3%A9stos%20de%20cualquier%20cambio%20en%20su%20estado%2C%20normalmente%20llamando%20a" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern&amp;annotation=En%20este%20screencast%20voy%20a%20explicaros%20el%20patr%C3%B3n%20de%20dise%C3%B1o%20Observer%20%28observador%29%20en%20PHP%2C%20que%20consiste%20en%20crear%20objetos%20observables%20que%20mantienen%20una%20lista%20de%20observadores%20y%20les%20notifica%20a%20%C3%A9stos%20de%20cualquier%20cambio%20en%20su%20estado%2C%20normalmente%20llamando%20a" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern&amp;s=En%20este%20screencast%20voy%20a%20explicaros%20el%20patr%C3%B3n%20de%20dise%C3%B1o%20Observer%20%28observador%29%20en%20PHP%2C%20que%20consiste%20en%20crear%20objetos%20observables%20que%20mantienen%20una%20lista%20de%20observadores%20y%20les%20notifica%20a%20%C3%A9stos%20de%20cualquier%20cambio%20en%20su%20estado%2C%20normalmente%20llamando%20a" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Observer%20Pattern%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fvideotutorial-patrones-de-diseno-en-php-observer-pattern%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-observer-pattern/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP &#8211; Factory Pattern</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-factory-pattern/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-factory-pattern/#comments</comments>
		<pubDate>Fri, 09 Apr 2010 11:43:25 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=785</guid>
		<description><![CDATA[Continuamos la serie de videos sobre patrones de diseño en PHP con el patrón creacional Factory, que consiste en un método para crear objetos cuando no sabemos la clase exacta del objeto que va a ser creado. De esta manera encapsulamos clases en una clase general de la que heredarán distintas subclases. Aunque el ejemplo [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/screencast_php_patterns.png" alt="" title="screencast_php_patterns" width="163" height="104" class="derecha alignright size-full wp-image-774" />Continuamos la serie de videos sobre patrones de diseño en PHP con el patrón creacional Factory, que consiste en un método para crear objetos cuando no sabemos la clase exacta del objeto que va a ser creado. De esta manera encapsulamos clases en una clase general de la que heredarán distintas subclases. Aunque el ejemplo utilizado es muy sencillo, este patrón es bastante interesante si tenemos en cuenta que podemos redefinir métodos en cada subclase, así como automatizar la creación de objetos utilizando variables (que podemos obtener de un fichero de settings).<br />
<span id="more-785"></span></p>
<h3>Ver screencast (duración: 5:41)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgdS9aAA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-9PatronesDeDiseoEnPHPFactoryPattern135.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (9 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-9PatronesDeDiseoEnPHPFactoryPattern389.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (6 MB)</a></li>
</ul>
<p></p>
<p>Podéis ver el resto de screencasts en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño y desarrollo web, codeigniter, PHP, CSS3">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.</p>
<h3>Ejemplo de implementación</h3>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
abstract <span style="color: #000000; font-weight: bold;">class</span> Vehiculo<span style="color: #009900;">&#123;</span>
	protected <span style="color: #000088;">$numruedas</span><span style="color: #339933;">;</span>
	<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> getNumruedas<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">return</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">numruedas</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> Coche <span style="color: #000000; font-weight: bold;">extends</span> Vehiculo<span style="color: #009900;">&#123;</span>
	protected <span style="color: #000088;">$numruedas</span> <span style="color: #339933;">=</span> <span style="color: #cc66cc;">4</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> Bici <span style="color: #000000; font-weight: bold;">extends</span> Vehiculo<span style="color: #009900;">&#123;</span>
	protected <span style="color: #000088;">$numruedas</span> <span style="color: #339933;">=</span> <span style="color: #cc66cc;">2</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> VehiculoFactory<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">public</span> static <span style="color: #000000; font-weight: bold;">function</span> crearVehiculo<span style="color: #009900;">&#40;</span><span style="color: #000088;">$tipo</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #000088;">$clasebase</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">'Vehiculo'</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #990000;">class_exists</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$tipo</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">&amp;&amp;</span> <span style="color: #990000;">is_subclass_of</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$tipo</span><span style="color: #339933;">,</span> <span style="color: #000088;">$clasebase</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span>
			<span style="color: #b1b100;">return</span> <span style="color: #000000; font-weight: bold;">new</span> <span style="color: #000088;">$tipo</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">else</span>
			throw <span style="color: #000000; font-weight: bold;">new</span> Exception<span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;No se reconoce el tipo de vehiculo <span style="color: #006699; font-weight: bold;">$tipo</span>&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #000088;">$vehiculo</span> <span style="color: #339933;">=</span> <span style="color: #990000;">Array</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Bici'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'Coche'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$vehiculo</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$v</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
	<span style="color: #b1b100;">echo</span> <span style="color: #0000ff;">&quot;El vehiculo <span style="color: #006699; font-weight: bold;">$v</span> tiene &quot;</span><span style="color: #339933;">.</span>VehiculoFactory<span style="color: #339933;">::</span><span style="color: #004000;">crearVehiculo</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$v</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">getNumruedas</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">&quot; ruedas&lt;br /&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>


<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern&amp;bodytext=Continuamos%20la%20serie%20de%20videos%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%20con%20el%20patr%C3%B3n%20creacional%20Factory%2C%20que%20consiste%20en%20un%20m%C3%A9todo%20para%20crear%20objetos%20cuando%20no%20sabemos%20la%20clase%20exacta%20del%20objeto%20que%20va%20a%20ser%20creado.%20De%20esta%20manera%20encapsulamos%20clases%20en%20u" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern&amp;notes=Continuamos%20la%20serie%20de%20videos%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%20con%20el%20patr%C3%B3n%20creacional%20Factory%2C%20que%20consiste%20en%20un%20m%C3%A9todo%20para%20crear%20objetos%20cuando%20no%20sabemos%20la%20clase%20exacta%20del%20objeto%20que%20va%20a%20ser%20creado.%20De%20esta%20manera%20encapsulamos%20clases%20en%20u" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern&amp;annotation=Continuamos%20la%20serie%20de%20videos%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%20con%20el%20patr%C3%B3n%20creacional%20Factory%2C%20que%20consiste%20en%20un%20m%C3%A9todo%20para%20crear%20objetos%20cuando%20no%20sabemos%20la%20clase%20exacta%20del%20objeto%20que%20va%20a%20ser%20creado.%20De%20esta%20manera%20encapsulamos%20clases%20en%20u" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern&amp;s=Continuamos%20la%20serie%20de%20videos%20sobre%20patrones%20de%20dise%C3%B1o%20en%20PHP%20con%20el%20patr%C3%B3n%20creacional%20Factory%2C%20que%20consiste%20en%20un%20m%C3%A9todo%20para%20crear%20objetos%20cuando%20no%20sabemos%20la%20clase%20exacta%20del%20objeto%20que%20va%20a%20ser%20creado.%20De%20esta%20manera%20encapsulamos%20clases%20en%20u" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Factory%20Pattern%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-factory-pattern%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-factory-pattern/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP &#8211; Singleton Pattern</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-singleton-pattern/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-singleton-pattern/#comments</comments>
		<pubDate>Tue, 30 Mar 2010 12:38:49 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=755</guid>
		<description><![CDATA[Hoy os traigo el primero de una serie de videos cortos en los que voy a explicar algunos de los patrones diseño OOP más comunes en PHP. Un patrón de diseño consiste en una solución a un problema común en el desarrollo de software. En el caso de PHP, estos patrones son los que nos [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/screencast_php_patterns.png" alt="" title="screencast_php_patterns" width="163" height="104" class="derecha alignright size-full wp-image-774" />Hoy os traigo el primero de una serie de videos cortos en los que voy a explicar algunos de los patrones diseño OOP más comunes en PHP. Un patrón de diseño consiste en una solución a un problema común en el desarrollo de software. En el caso de PHP, estos patrones son los que nos permiten aprovechar realmente toda la potencia de orientación a objetos de PHP5. Estos videos no pretenden ser tutoriales exhaustivos, sino simplemente una visión general y rápida de en qué consiste cada patrón, para aquellos que no estén familiarizados con esta metodología.</p>
<p>Empezaremos con el patrón <em>Singleton</em>, ya que es el más fácil de entender y utilizar. Hay varias maneras de implementar una clase singleton, pero aquí os voy a mostrar la forma más sencilla.<br />
<span id="more-755"></span></p>
<h3>Ver screencast (duración: 6:00)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgdHaMAA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern307.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (12 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern667.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (7 MB)</a></li>
</ul>
<p></p>
<p>Podéis ver el resto de screencasts en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño, desarrollo web, codeigniter, CSS3">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.</p>
<h3>¿Qué es un Singleton?</h3>
<p>Un singleton consiste en una clase que solo puede tener una instancia y provee de un punto global de acceso a ella. Para ello se crea una instancia de la clase la primera vez que se referencia, y se devuelve ésta en posteriores llamadas. Esto ayuda a crear clases reusables y no depender de variables globales.</p>
<p>Un claro ejemplo de uso es cuando diseñamos una clase para gestionar la conexion y querys con la base de datos. A lo largo de nuestro script crearemos instancias de esa clase, pero nos interesa que siempre sea la misma ya que todas las conexiones compartirán los mismos parámetros y solo cambiará el contenido del query, por lo que no necesitamos una nueva instancia cada vez, consiguiendo con ello una mejora en el rendimiento.</p>
<h3>Ejemplo de implementación</h3>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">class</span> Singleton
<span style="color: #009900;">&#123;</span>
	<span style="color: #000000; font-weight: bold;">private</span> static <span style="color: #000088;">$singleInstancia</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span> <span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #000000; font-weight: bold;">public</span> static <span style="color: #000000; font-weight: bold;">function</span> getInstancia<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$singleInstancia</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
			<span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$singleInstancia</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> <span style="color: #000000; font-weight: bold;">self</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
		<span style="color: #b1b100;">return</span> <span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$singleInstancia</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
        <span style="color: #666666; font-style: italic;">/* A partir de aquí vamos añadiendo los métodos la clase */</span>
	<span style="color: #000000; font-weight: bold;">function</span> Metodo<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		<span style="color: #990000;">var_dump</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$singleInstancia</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Usaremos la clase de esta manera:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$mysingleton</span> <span style="color: #339933;">=</span> Singleton<span style="color: #339933;">::</span><span style="color: #004000;">getInstancia</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$mysingleton</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">Metodo</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Para hacer nuestro singleton más robusto podríamos definir algunos de los <a href="http://php.net/manual/en/language.oop5.magic.php">metódos &#8216;mágicos&#8217;</a> de PHP para evitar el clonado y manejar la serialización, pero los he omitido para mantener la sencillez del ejemplo.</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern&amp;bodytext=Hoy%20os%20traigo%20el%20primero%20de%20una%20serie%20de%20videos%20cortos%20en%20los%20que%20voy%20a%20explicar%20algunos%20de%20los%20patrones%20dise%C3%B1o%20OOP%20m%C3%A1s%20comunes%20en%20PHP.%20Un%20patr%C3%B3n%20de%20dise%C3%B1o%20consiste%20en%20una%20soluci%C3%B3n%20a%20un%20problema%20com%C3%BAn%20en%20el%20desarrollo%20de%20software.%20En%20el%20caso%20de" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern&amp;notes=Hoy%20os%20traigo%20el%20primero%20de%20una%20serie%20de%20videos%20cortos%20en%20los%20que%20voy%20a%20explicar%20algunos%20de%20los%20patrones%20dise%C3%B1o%20OOP%20m%C3%A1s%20comunes%20en%20PHP.%20Un%20patr%C3%B3n%20de%20dise%C3%B1o%20consiste%20en%20una%20soluci%C3%B3n%20a%20un%20problema%20com%C3%BAn%20en%20el%20desarrollo%20de%20software.%20En%20el%20caso%20de" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern&amp;annotation=Hoy%20os%20traigo%20el%20primero%20de%20una%20serie%20de%20videos%20cortos%20en%20los%20que%20voy%20a%20explicar%20algunos%20de%20los%20patrones%20dise%C3%B1o%20OOP%20m%C3%A1s%20comunes%20en%20PHP.%20Un%20patr%C3%B3n%20de%20dise%C3%B1o%20consiste%20en%20una%20soluci%C3%B3n%20a%20un%20problema%20com%C3%BAn%20en%20el%20desarrollo%20de%20software.%20En%20el%20caso%20de" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;title=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F&amp;t=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern&amp;s=Hoy%20os%20traigo%20el%20primero%20de%20una%20serie%20de%20videos%20cortos%20en%20los%20que%20voy%20a%20explicar%20algunos%20de%20los%20patrones%20dise%C3%B1o%20OOP%20m%C3%A1s%20comunes%20en%20PHP.%20Un%20patr%C3%B3n%20de%20dise%C3%B1o%20consiste%20en%20una%20soluci%C3%B3n%20a%20un%20problema%20com%C3%BAn%20en%20el%20desarrollo%20de%20software.%20En%20el%20caso%20de" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20Patrones%20de%20dise%C3%B1o%20en%20PHP%20-%20Singleton%20Pattern%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-patrones-de-diseno-en-php-singleton-pattern%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-singleton-pattern/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Aterrizamos en el Planet Webdev</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/aterrizamos-en-el-planet-webdev/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/aterrizamos-en-el-planet-webdev/#comments</comments>
		<pubDate>Thu, 25 Mar 2010 10:20:07 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[Desarrollo Web]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=739</guid>
		<description><![CDATA[Es un honor anunciar que desde ayer (gracias a SigT) este blog pasa a formar parte del Planet Webdev, lo que significa que los artículos publicados aquí se mostrarán a su vez en la portada y el feed del Planet. Un Planet es una web que reune feeds de distintos sitios de una temática común, [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/planetwebdev.png" alt="planetwebdev" title="planetwebdev" width="163" height="104" class="derecha alignright size-full wp-image-748" />Es un honor anunciar que desde ayer (gracias a <a href="http://sigt.net/archivo/inaguramos-el-planeta-de-desarrollo-web.xhtml">SigT</a>) este blog pasa a formar parte del <a href="http://planetwebdev.net/" title="Planet sobre desarrollo web">Planet Webdev</a>, lo que significa que los artículos publicados aquí se mostrarán a su vez en la portada y el feed del Planet. Un Planet es una web que reune feeds de distintos sitios de una temática común, en este caso sobre desarrollo web.</p>
<p>Para los que acaben de conocer mi blog a través del planet, les recomiendo que le echen un vistazo a mis <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Screencasts desarrollo web">Videotutoriales</a>, sobre todo si están interesados en el framework PHP CodeIgniter (aunque también hay alguno sobre CSS y jQuery).</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;title=Aterrizamos%20en%20el%20Planet%20Webdev&amp;bodytext=Es%20un%20honor%20anunciar%20que%20desde%20ayer%20%28gracias%20a%20SigT%29%20este%20blog%20pasa%20a%20formar%20parte%20del%20Planet%20Webdev%2C%20lo%20que%20significa%20que%20los%20art%C3%ADculos%20publicados%20aqu%C3%AD%20se%20mostrar%C3%A1n%20a%20su%20vez%20en%20la%20portada%20y%20el%20feed%20del%20Planet.%20Un%20Planet%20es%20una%20web%20que%20reune%20feeds" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;title=Aterrizamos%20en%20el%20Planet%20Webdev&amp;notes=Es%20un%20honor%20anunciar%20que%20desde%20ayer%20%28gracias%20a%20SigT%29%20este%20blog%20pasa%20a%20formar%20parte%20del%20Planet%20Webdev%2C%20lo%20que%20significa%20que%20los%20art%C3%ADculos%20publicados%20aqu%C3%AD%20se%20mostrar%C3%A1n%20a%20su%20vez%20en%20la%20portada%20y%20el%20feed%20del%20Planet.%20Un%20Planet%20es%20una%20web%20que%20reune%20feeds" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;t=Aterrizamos%20en%20el%20Planet%20Webdev" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;title=Aterrizamos%20en%20el%20Planet%20Webdev&amp;annotation=Es%20un%20honor%20anunciar%20que%20desde%20ayer%20%28gracias%20a%20SigT%29%20este%20blog%20pasa%20a%20formar%20parte%20del%20Planet%20Webdev%2C%20lo%20que%20significa%20que%20los%20art%C3%ADculos%20publicados%20aqu%C3%AD%20se%20mostrar%C3%A1n%20a%20su%20vez%20en%20la%20portada%20y%20el%20feed%20del%20Planet.%20Un%20Planet%20es%20una%20web%20que%20reune%20feeds" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Aterrizamos%20en%20el%20Planet%20Webdev&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;title=Aterrizamos%20en%20el%20Planet%20Webdev" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F&amp;t=Aterrizamos%20en%20el%20Planet%20Webdev&amp;s=Es%20un%20honor%20anunciar%20que%20desde%20ayer%20%28gracias%20a%20SigT%29%20este%20blog%20pasa%20a%20formar%20parte%20del%20Planet%20Webdev%2C%20lo%20que%20significa%20que%20los%20art%C3%ADculos%20publicados%20aqu%C3%AD%20se%20mostrar%C3%A1n%20a%20su%20vez%20en%20la%20portada%20y%20el%20feed%20del%20Planet.%20Un%20Planet%20es%20una%20web%20que%20reune%20feeds" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Aterrizamos%20en%20el%20Planet%20Webdev%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Faterrizamos-en-el-planet-webdev%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/aterrizamos-en-el-planet-webdev/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Cómo hacer un plugin jQuery &#8211; Menú acordeón multinivel</title>
		<link>http://www.davidrojas.net/index.php/jquery/screencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel/</link>
		<comments>http://www.davidrojas.net/index.php/jquery/screencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel/#comments</comments>
		<pubDate>Wed, 03 Mar 2010 18:39:11 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[Screencasts]]></category>
		<category><![CDATA[jQuery]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=704</guid>
		<description><![CDATA[Respondiendo a la multitud de peticiones en los comentarios del artículo sobre cómo crear un menú en acordeón, aquí os muestro cómo hacer el mismo menú pero con soporte para varios niveles.
Este menú está basado en el anterior, y como apenas necesitaba un pequeño cambio en el javascript para hacerlo multinivel, he aprovechado para convertirlo [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/03/jquery_accordion_screencast.png" alt="" title="jquery_accordion_screencast" width="163" height="104" class="derecha alignright size-full wp-image-718" />Respondiendo a la multitud de peticiones en los comentarios del artículo sobre <a href="http://www.davidrojas.net/index.php/diseno-web/menu-vertical-en-acordeon-con-css-y-jquery/" title="Menú vertical en acordeón con CSS y jQuery">cómo crear un menú en acordeón</a>, aquí os muestro cómo hacer el mismo menú pero con soporte para varios niveles.<br />
Este menú está basado en el anterior, y como apenas necesitaba un pequeño cambio en el javascript para hacerlo multinivel, he aprovechado para convertirlo en un plugin y enseñaros en un screencast cómo hacer vuestros propios plugins en jQuery.</p>
<p><em class="linkem"><a href='http://www.davidrojas.net/demos/acordeon_multinivel.html' title="Demo menú vertical en acordeón multinivel" target="_blank">Ver Demo menú acordeón multinivel</a></em><br />
<span id="more-704"></span></p>
<h3>Ver screencast (duración: 8:17)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgcqcaQA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-7CmoHacerUnPluginJQueryMenAcordenMultinivel831.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (25 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-7CmoHacerUnPluginJQueryMenAcordenMultinivel409.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (13 MB)</a></li>
</ul>
<p></p>
<p>No olvidéis echarle un vistazo al resto de videos en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño, desarrollo web, jquery, codeigniter, CSS3">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.</p>
<h3>Cómo usarlo</h3>
<p>Para ver el HTML y CSS no tenéis mas que ver el código fuente del ejemplo de arriba, es bastante similar al del artículo anterior. En el html se añade un nivel más de anidamiento de listas, y en el CSS se le añade la regla <code>#menu ul li li{padding-left: 10px;}</code> para que los niveles inferiores tengan padding (esto podéis modificarlo como queráis).<br />
Para cargar el javascript, podéis copiar el código en la cabecera tal como está en el ejemplo, o bien <em class="linkem"><a href='http://www.davidrojas.net/wp-content/uploads/2010/03/jquery.accordion.js'>descargaros el archivo JS con el plugin</a></em> e insertarlo de esta manera:</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>script src<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;jquery.accordion.js&quot;</span> type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;text/javascript&quot;</span> charset<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;utf-8&quot;</span><span style="color: #339933;">&gt;&lt;/</span>script<span style="color: #339933;">&gt;</span></pre></div></div>

<p>Después sólo os queda llamar al plugin:</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>script type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;text/javascript&quot;</span> charset<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;utf-8&quot;</span><span style="color: #339933;">&gt;</span>
$<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
      $<span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'#menu'</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">accordion</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #339933;">&lt;/</span>script<span style="color: #339933;">&gt;</span></pre></div></div>

<p></p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;title=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel&amp;bodytext=Respondiendo%20a%20la%20multitud%20de%20peticiones%20en%20los%20comentarios%20del%20art%C3%ADculo%20sobre%20c%C3%B3mo%20crear%20un%20men%C3%BA%20en%20acorde%C3%B3n%2C%20aqu%C3%AD%20os%20muestro%20c%C3%B3mo%20hacer%20el%20mismo%20men%C3%BA%20pero%20con%20soporte%20para%20varios%20niveles.%0D%0AEste%20men%C3%BA%20est%C3%A1%20basado%20en%20el%20anterior%2C%20y%20como%20apena" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;title=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel&amp;notes=Respondiendo%20a%20la%20multitud%20de%20peticiones%20en%20los%20comentarios%20del%20art%C3%ADculo%20sobre%20c%C3%B3mo%20crear%20un%20men%C3%BA%20en%20acorde%C3%B3n%2C%20aqu%C3%AD%20os%20muestro%20c%C3%B3mo%20hacer%20el%20mismo%20men%C3%BA%20pero%20con%20soporte%20para%20varios%20niveles.%0D%0AEste%20men%C3%BA%20est%C3%A1%20basado%20en%20el%20anterior%2C%20y%20como%20apena" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;t=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;title=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel&amp;annotation=Respondiendo%20a%20la%20multitud%20de%20peticiones%20en%20los%20comentarios%20del%20art%C3%ADculo%20sobre%20c%C3%B3mo%20crear%20un%20men%C3%BA%20en%20acorde%C3%B3n%2C%20aqu%C3%AD%20os%20muestro%20c%C3%B3mo%20hacer%20el%20mismo%20men%C3%BA%20pero%20con%20soporte%20para%20varios%20niveles.%0D%0AEste%20men%C3%BA%20est%C3%A1%20basado%20en%20el%20anterior%2C%20y%20como%20apena" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;title=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F&amp;t=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel&amp;s=Respondiendo%20a%20la%20multitud%20de%20peticiones%20en%20los%20comentarios%20del%20art%C3%ADculo%20sobre%20c%C3%B3mo%20crear%20un%20men%C3%BA%20en%20acorde%C3%B3n%2C%20aqu%C3%AD%20os%20muestro%20c%C3%B3mo%20hacer%20el%20mismo%20men%C3%BA%20pero%20con%20soporte%20para%20varios%20niveles.%0D%0AEste%20men%C3%BA%20est%C3%A1%20basado%20en%20el%20anterior%2C%20y%20como%20apena" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20C%C3%B3mo%20hacer%20un%20plugin%20jQuery%20-%20Men%C3%BA%20acorde%C3%B3n%20multinivel%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fjquery%2Fscreencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/jquery/screencast-como-hacer-un-plugin-jquery-menu-acordeon-multinivel/feed/</wfw:commentRss>
		<slash:comments>13</slash:comments>
		</item>
		<item>
		<title>URLs amigables en CodeIgniter: Controlador &#8216;catch-all&#8217;</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/urls-amigables-en-codeigniter-controlador-catch-all/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/urls-amigables-en-codeigniter-controlador-catch-all/#comments</comments>
		<pubDate>Wed, 10 Feb 2010 22:46:45 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CodeIgniter]]></category>
		<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=661</guid>
		<description><![CDATA[Supongamos que estamos programando un CMS en CodeIgniter para integrarlo en nuestros proyectos, y queremos generar urls del estilo www.dominio.com/titulo-de-la-pagina. Una manera de enfocarlo sería por ejemplo crear un controlador Paginas con un método cargar, al que se le pasará como parámetro el título de la página en cuestión. De esta manera se llamaría a [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2009/09/codeigniter_logo.png" alt="" title="codeigniter_logo" width="163" height="104" class="derecha alignright size-full wp-image-360" />Supongamos que estamos programando un CMS en CodeIgniter para integrarlo en nuestros proyectos, y queremos generar urls del estilo <em>www.dominio.com/titulo-de-la-pagina</em>. Una manera de enfocarlo sería por ejemplo crear un controlador <em>Paginas</em> con un método <em>cargar</em>, al que se le pasará como parámetro el título de la página en cuestión. De esta manera se llamaría a la url <em>www.dominio.com/paginas/cargar/titulo-de-la-pagina</em>. Para eliminar <em>/paginas/cargar/</em> de la url editaríamos el fichero <a href="http://www.codeignitor.com/user_guide/general/routing.html" title="Rutas en CodeIgniter">routing.php</a>.</p>
<p>Esto supone un problema: si añadimos una regla genérica a las rutas para redirigir cualquier url al controlador <em>paginas/cargar</em>, no funcionaría el resto de controladores de nuestra aplicación. Deberíamos añadir una regla para cada página o bien para cada controlador que tengamos, con lo cual perdemos dinamismo y nos obliga a editar el fichero de rutas con cada cambio.<br />
<span id="more-661"></span></p>
<h3>Extendiendo la librería Router</h3>
<p>Lo que nos interesa es un controlador &#8216;catch-all&#8217;, que capture cualquier texto de la url y lo procese siempre que no exista otro controlador con ese nombre. Para ello vamos a extender la librería de rutas creando un archivo <em>MY_Router.php</em> y guardándolo en <em>application/libraries/</em>. El método estándar para extender librerías es crear un archivo con el mismo nombre añadiendo el prefijo <em>MY_</em>. Aquí tenéis el código de <em>MY_Router.php</em>:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000000; font-weight: bold;">class</span> MY_Router <span style="color: #000000; font-weight: bold;">extends</span> CI_Router <span style="color: #009900;">&#123;</span>
&nbsp;
    <span style="color: #000000; font-weight: bold;">function</span> MY_Router<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>
    <span style="color: #009900;">&#123;</span>
        parent<span style="color: #339933;">::</span><span style="color: #004000;">CI_Router</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
    <span style="color: #000000; font-weight: bold;">function</span> _validate_request<span style="color: #009900;">&#40;</span><span style="color: #000088;">$segments</span><span style="color: #009900;">&#41;</span>
    <span style="color: #009900;">&#123;</span>
        <span style="color: #666666; font-style: italic;">// Comprueba que el controlador no existe</span>
        <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #990000;">file_exists</span><span style="color: #009900;">&#40;</span>APPPATH<span style="color: #339933;">.</span><span style="color: #0000ff;">'controllers/'</span><span style="color: #339933;">.</span><span style="color: #000088;">$segments</span><span style="color: #009900;">&#91;</span><span style="color: #cc66cc;">0</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">.</span>EXT<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span>
        <span style="color: #009900;">&#123;</span>
            <span style="color: #000088;">$segments</span> <span style="color: #339933;">=</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;paginas&quot;</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">&quot;cargar&quot;</span><span style="color: #339933;">,</span> <span style="color: #000088;">$segments</span><span style="color: #009900;">&#91;</span><span style="color: #cc66cc;">0</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
        <span style="color: #009900;">&#125;</span>
        <span style="color: #b1b100;">return</span> parent<span style="color: #339933;">::</span>_validate_request<span style="color: #009900;">&#40;</span><span style="color: #000088;">$segments</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>

<p>Como veis lo que hacemos es extender el método <em>_validate_request</em> de la librería <em>Router</em>, que es el que procesa los segmentos de nuestra url. En él comprobamos si el nombre del primer segmento de la url corresponde a un controlador existente, si no es así añadimos al array de segmentos nuestro controlador y método <em>paginas</em> y <em>cargar</em> y llamamos al método <em>_validate_request</em> de la librería Router original pasándole estos parámetros.</p>
<p>Finalmente nos queda crear el controlador <em>Paginas.php</em>:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000000; font-weight: bold;">class</span> Paginas <span style="color: #000000; font-weight: bold;">extends</span> Controller <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
        	parent<span style="color: #339933;">::</span><span style="color: #004000;">Controller</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
    <span style="color: #000000; font-weight: bold;">function</span> cargar<span style="color: #009900;">&#40;</span><span style="color: #000088;">$title</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
    	<span style="color: #339933;">.....</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></div></div>

<p>Dentro de la función <em>cargar</em>, <code>$title</code> contendrá el título de nuestra url, es decir el primer segmento que le pasamos: <em>www.dominio.com/titulo-de-la-pagina</em>. En dicha función lo gestionaremos como nos interese, siendo lo más lógico utilizar ese título como identificador de nuestra página y buscarla en la base de datos para mostrarla.</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;title=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27&amp;bodytext=Supongamos%20que%20estamos%20programando%20un%20CMS%20en%20CodeIgniter%20para%20integrarlo%20en%20nuestros%20proyectos%2C%20y%20queremos%20generar%20urls%20del%20estilo%20www.dominio.com%2Ftitulo-de-la-pagina.%20Una%20manera%20de%20enfocarlo%20ser%C3%ADa%20por%20ejemplo%20crear%20un%20controlador%20Paginas%20con%20un%20m%C3%A9" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;title=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27&amp;notes=Supongamos%20que%20estamos%20programando%20un%20CMS%20en%20CodeIgniter%20para%20integrarlo%20en%20nuestros%20proyectos%2C%20y%20queremos%20generar%20urls%20del%20estilo%20www.dominio.com%2Ftitulo-de-la-pagina.%20Una%20manera%20de%20enfocarlo%20ser%C3%ADa%20por%20ejemplo%20crear%20un%20controlador%20Paginas%20con%20un%20m%C3%A9" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;t=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;title=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27&amp;annotation=Supongamos%20que%20estamos%20programando%20un%20CMS%20en%20CodeIgniter%20para%20integrarlo%20en%20nuestros%20proyectos%2C%20y%20queremos%20generar%20urls%20del%20estilo%20www.dominio.com%2Ftitulo-de-la-pagina.%20Una%20manera%20de%20enfocarlo%20ser%C3%ADa%20por%20ejemplo%20crear%20un%20controlador%20Paginas%20con%20un%20m%C3%A9" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;title=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F&amp;t=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27&amp;s=Supongamos%20que%20estamos%20programando%20un%20CMS%20en%20CodeIgniter%20para%20integrarlo%20en%20nuestros%20proyectos%2C%20y%20queremos%20generar%20urls%20del%20estilo%20www.dominio.com%2Ftitulo-de-la-pagina.%20Una%20manera%20de%20enfocarlo%20ser%C3%ADa%20por%20ejemplo%20crear%20un%20controlador%20Paginas%20con%20un%20m%C3%A9" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=URLs%20amigables%20en%20CodeIgniter%3A%20Controlador%20%27catch-all%27%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Furls-amigables-en-codeigniter-controlador-catch-all%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/urls-amigables-en-codeigniter-controlador-catch-all/feed/</wfw:commentRss>
		<slash:comments>14</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Mejora progresiva con CSS3</title>
		<link>http://www.davidrojas.net/index.php/diseno-web/screencast-mejora-progresiva-con-css3/</link>
		<comments>http://www.davidrojas.net/index.php/diseno-web/screencast-mejora-progresiva-con-css3/#comments</comments>
		<pubDate>Tue, 12 Jan 2010 19:00:05 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[Diseño Web]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=598</guid>
		<description><![CDATA[En este videotutorial voy a enseñaros algunas propiedades de CSS3 que nos servirán para mejorar visualmente nuestros diseños sin necesidad de usar imágenes o javascript, concretamente el manejo de sombras, gradientes y transformaciones sólo con CSS. Puesto que CSS3 aún no es un estándar, tendremos que usar las extensiones propietarias que implementan los navegadores más [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/01/css3_screencast.png" alt="" title="css3_screencast" width="163" height="104" class="derecha alignright size-full wp-image-640" />En este videotutorial voy a enseñaros algunas propiedades de <a href="http://www.css3.info/preview/" title="Información sobre CSS3 (inglés)">CSS3</a> que nos servirán para mejorar visualmente nuestros diseños sin necesidad de usar imágenes o javascript, concretamente el manejo de sombras, gradientes y transformaciones sólo con CSS. Puesto que <a href="http://www.w3.org/TR/css3-roadmap/" title="Roadmap de CSS3">CSS3 aún no es un estándar</a>, tendremos que usar las extensiones propietarias que implementan los navegadores más modernos, como las últimas versiones de Safari, Chrome y Firefox. Estas propiedades generalmente contiene el prefijo <code>-moz</code> para Firefox y <code>-webkit</code> para Safari y Chrome (webkit es que el motor utilizado en estos navegadores).</p>
<p><em class="linkem"><a href='http://www.davidrojas.net/demos/css3/' title="Demo mejora con CSS3" target="_blank">Ver Demo CSS3</a></em><br />
<span id="more-598"></span></p>
<h3>Ver screencast (duración: 15:49)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgb2DQwA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-6MejoraProgresivaConCSS3843.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (46 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-6MejoraProgresivaConCSS3510.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (24 MB)</a></li>
</ul>
<p></p>
<p>Como siempre, podéis encontrar todos los screencasts en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño, desarrollo web, codeigniter, CSS3">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.</p>
<h3>HTML y CSS</h3>
<p>En el fuente del ejemplo de arriba tenéis código completo, pero voy a destacaros aquí las partes importantes. En el CSS:</p>

<div class="wp_syntax"><div class="code"><pre class="css" style="font-family:monospace;">a.foto<span style="color: #00AA00;">&#123;</span>
  <span style="color: #000000; font-weight: bold;">background</span><span style="color: #00AA00;">:</span> -webkit-gradient<span style="color: #00AA00;">&#40;</span>linear<span style="color: #00AA00;">,</span> <span style="color: #000000; font-weight: bold;">left</span> <span style="color: #000000; font-weight: bold;">top</span><span style="color: #00AA00;">,</span> <span style="color: #000000; font-weight: bold;">left</span> <span style="color: #000000; font-weight: bold;">bottom</span><span style="color: #00AA00;">,</span> from<span style="color: #00AA00;">&#40;</span><span style="color: #993333;">rgb</span><span style="color: #00AA00;">&#40;</span><span style="color: #cc66cc;">255</span><span style="color: #00AA00;">,</span> <span style="color: #cc66cc;">255</span><span style="color: #00AA00;">,</span> <span style="color: #cc66cc;">255</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">,</span> to<span style="color: #00AA00;">&#40;</span><span style="color: #993333;">rgb</span><span style="color: #00AA00;">&#40;</span><span style="color: #cc66cc;">207</span><span style="color: #00AA00;">,</span> <span style="color: #cc66cc;">207</span><span style="color: #00AA00;">,</span> <span style="color: #cc66cc;">207</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">;</span>
  -webkit-border-radius<span style="color: #00AA00;">:</span><span style="color: #933;">8px</span><span style="color: #00AA00;">;</span>
  -moz-border-radius<span style="color: #00AA00;">:</span><span style="color: #933;">8px</span><span style="color: #00AA00;">;</span>
  -webkit-box-shadow<span style="color: #00AA00;">:</span><span style="color: #933;">0px</span> <span style="color: #933;">0px</span> <span style="color: #933;">20px</span> <span style="color: #cc00cc;">#6F5F4C</span><span style="color: #00AA00;">;</span>
  -moz-box-shadow<span style="color: #00AA00;">:</span><span style="color: #933;">0px</span> <span style="color: #933;">0px</span> <span style="color: #933;">20px</span> <span style="color: #cc00cc;">#6F5F4C</span><span style="color: #00AA00;">;</span>
  -webkit-transition<span style="color: #3333ff;">:all </span>.3s linear<span style="color: #00AA00;">;</span>
<span style="color: #00AA00;">&#125;</span>
a<span style="color: #6666ff;">.foto</span><span style="color: #3333ff;">:hover</span><span style="color: #00AA00;">&#123;</span>
  -webkit-transform<span style="color: #00AA00;">:</span> rotate<span style="color: #00AA00;">&#40;</span>-5deg<span style="color: #00AA00;">&#41;</span> scale<span style="color: #00AA00;">&#40;</span><span style="color: #cc66cc;">1.08</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">;</span>
  -moz-transform<span style="color: #00AA00;">:</span> rotate<span style="color: #00AA00;">&#40;</span>-5deg<span style="color: #00AA00;">&#41;</span> scale<span style="color: #00AA00;">&#40;</span><span style="color: #cc66cc;">1.08</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">;</span>
<span style="color: #00AA00;">&#125;</span>
a<span style="color: #6666ff;">.foto</span> span<span style="color: #00AA00;">&#123;</span>
  <span style="color: #000000; font-weight: bold;">text-shadow</span><span style="color: #00AA00;">:</span><span style="color: #933;">1px</span> <span style="color: #933;">1px</span> <span style="color: #933;">2px</span> <span style="color: #cc00cc;">#9F886D</span><span style="color: #00AA00;">;</span>
<span style="color: #00AA00;">&#125;</span></pre></div></div>

<p>Y el HTML:</p>

<div class="wp_syntax"><div class="code"><pre class="html4strict" style="font-family:monospace;"><span style="color: #009900;">&lt;<span style="color: #000000; font-weight: bold;">a</span> <span style="color: #000066;">class</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">&quot;foto&quot;</span> <span style="color: #000066;">href</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">&quot;#&quot;</span>&gt;</span>
   <span style="color: #009900;">&lt;<span style="color: #000000; font-weight: bold;">img</span> <span style="color: #000066;">src</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">&quot;underworld_evolution.jpg&quot;</span> <span style="color: #000066;">alt</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">&quot;Underworld&quot;</span> <span style="color: #66cc66;">/</span>&gt;</span>
   <span style="color: #009900;">&lt;<span style="color: #000000; font-weight: bold;">span</span>&gt;</span>Texto descriptivo a pie de foto<span style="color: #009900;">&lt;<span style="color: #66cc66;">/</span><span style="color: #000000; font-weight: bold;">span</span>&gt;</span>
<span style="color: #009900;">&lt;<span style="color: #66cc66;">/</span><span style="color: #000000; font-weight: bold;">a</span>&gt;</span></pre></div></div>

<h3>¿Cuándo utilizar estas propiedades?</h3>
<p>Es importante tener siempre presente que estas propiedades no son soportadas por todos los navegadores, por lo tanto tenemos que restringir su uso a mejoras estéticas, que no influyan en la maquetación o la usabilidad de la web. Los navegadores que no las soporten (como Internet Explorer) simplemente verán una versión un poco &#8220;descafeinada&#8221; de nuestro sitio.</p>
<p>También es interesante conocer todo el potencial de CSS3 que nos proporciona <a href="http://developer.apple.com/safari/articles/cssrecipes.html" title="trucos CSS para webkit">webkit</a> si estamos interesados en el desarrollo web móvil, ya que además de Safari y Chrome, los navegadores de iPhone, Android, las nuevas Blackberry, Nokia y Palm Pre están basados en webkit.</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;title=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3&amp;bodytext=En%20este%20videotutorial%20voy%20a%20ense%C3%B1aros%20algunas%20propiedades%20de%20CSS3%20que%20nos%20servir%C3%A1n%20para%20mejorar%20visualmente%20nuestros%20dise%C3%B1os%20sin%20necesidad%20de%20usar%20im%C3%A1genes%20o%20javascript%2C%20concretamente%20el%20manejo%20de%20sombras%2C%20gradientes%20y%20transformaciones%20s%C3%B3lo%20con%20" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;title=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3&amp;notes=En%20este%20videotutorial%20voy%20a%20ense%C3%B1aros%20algunas%20propiedades%20de%20CSS3%20que%20nos%20servir%C3%A1n%20para%20mejorar%20visualmente%20nuestros%20dise%C3%B1os%20sin%20necesidad%20de%20usar%20im%C3%A1genes%20o%20javascript%2C%20concretamente%20el%20manejo%20de%20sombras%2C%20gradientes%20y%20transformaciones%20s%C3%B3lo%20con%20" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;t=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;title=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3&amp;annotation=En%20este%20videotutorial%20voy%20a%20ense%C3%B1aros%20algunas%20propiedades%20de%20CSS3%20que%20nos%20servir%C3%A1n%20para%20mejorar%20visualmente%20nuestros%20dise%C3%B1os%20sin%20necesidad%20de%20usar%20im%C3%A1genes%20o%20javascript%2C%20concretamente%20el%20manejo%20de%20sombras%2C%20gradientes%20y%20transformaciones%20s%C3%B3lo%20con%20" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;title=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F&amp;t=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3&amp;s=En%20este%20videotutorial%20voy%20a%20ense%C3%B1aros%20algunas%20propiedades%20de%20CSS3%20que%20nos%20servir%C3%A1n%20para%20mejorar%20visualmente%20nuestros%20dise%C3%B1os%20sin%20necesidad%20de%20usar%20im%C3%A1genes%20o%20javascript%2C%20concretamente%20el%20manejo%20de%20sombras%2C%20gradientes%20y%20transformaciones%20s%C3%B3lo%20con%20" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20Mejora%20progresiva%20con%20CSS3%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Fscreencast-mejora-progresiva-con-css3%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/diseno-web/screencast-mejora-progresiva-con-css3/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Hooks y creación de librerías con Codeigniter</title>
		<link>http://www.davidrojas.net/index.php/desarrollo-web/screencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter/</link>
		<comments>http://www.davidrojas.net/index.php/desarrollo-web/screencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter/#comments</comments>
		<pubDate>Sat, 02 Jan 2010 16:47:17 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CodeIgniter]]></category>
		<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Screencasts]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=582</guid>
		<description><![CDATA[A petición popular he creado un último screencast sobre CodeIgniter. En él os voy a enseñar un par de conceptos importantes para extender la funcionalidad del framework: los hooks y la creación de librerias. Como ejemplo crearé un sistema muy simple de autenticación, con una librería que contendrá una función para hacer login y otra [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2009/12/codeigniter_screencast_hook.png" alt="codeigniter_screencast_hook" title="codeigniter_screencast_hook" width="163" height="104" class="derecha alignright size-full wp-image-583" />A petición popular he creado un último screencast sobre CodeIgniter. En él os voy a enseñar un par de conceptos importantes para extender la funcionalidad del framework: los hooks y la creación de librerias. Como ejemplo crearé un sistema muy simple de autenticación, con una librería que contendrá una función para hacer login y otra para logout, y un hook que se disparará cada vez que se ejecute cualquier controlador. Los <a href="http://codeigniter.com/user_guide/general/hooks.html">hooks</a> son una utilidad que nos permite llamar a una función en determinadas fases de la ejecución del framework, por ejemplo antes o después de ejecutar cualquier controlador, el constructor de éste, etc.</p>
<p>Podéis encontrar el resto de screencasts en la <a href="http://www.davidrojas.net/index.php/category/screencasts/" title="Videotutoriales de diseño, desarrollo web y codeigniter">página de videotutoriales</a>, o suscribiros al <a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250" title="Enlace a videopodcast de David Rojas en iTunes">podcast de iTunes</a>.<br />
<span id="more-582"></span><br />
<em class="linkem"><a href='http://www.davidrojas.net/wp-content/uploads/2009/12/5_hooks_y_creacion_de_librerias_en_codeigniter_archivos.zip' title="Código ejemplo hooks y creación de librerias CodeIgniter, sistema de login básico">Descargar ficheros con el código del ejemplo.</a></em></p>
<h3>Ver screencast (duración: 24:02)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgbrSYQA" type="application/x-shockwave-flash" width="490" height="397" allowscriptaccess="always" allowfullscreen="true"></embed>
</div>
<ul>
<li><a href="http://blip.tv/file/get/Davidrojas-5HooksYCreacinDeLibrerasConCodeIgniter793.mov" title="Descargar versión alta calidad">Descargar videotutorial en alta calidad &#8211; MOV (67 MB)</a></li>
<li><a href="http://blip.tv/file/get/Davidrojas-5HooksYCreacinDeLibrerasConCodeIgniter290.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (35 MB)</a></li>
</ul>
<p></p>
<p>&raquo; Advertencia: El audio está un poco desincronizado con el vídeo. En algunas partes apenas se nota, pero en otras sí, sobre todo por el final. De todas formas creo que se entienden bastante bien los conceptos, y como es un video largo no he creído necesario volverlo a grabar.</p>
<p>Y con este sí finalizo la serie de videos sobre CodeIgniter. Mi próximo screencast será sobre algo relacionado con CSS y frontend, así que os recomiendo que os sigáis pasando por aquí a todos los que estéis interesados en todos los aspectos del desarrollo web en general y no sólo en la programación pura de backend.</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;title=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter&amp;bodytext=A%20petici%C3%B3n%20popular%20he%20creado%20un%20%C3%BAltimo%20screencast%20sobre%20CodeIgniter.%20En%20%C3%A9l%20os%20voy%20a%20ense%C3%B1ar%20un%20par%20de%20conceptos%20importantes%20para%20extender%20la%20funcionalidad%20del%20framework%3A%20los%20hooks%20y%20la%20creaci%C3%B3n%20de%20librerias.%20Como%20ejemplo%20crear%C3%A9%20un%20sistema%20muy%20s" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;title=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter&amp;notes=A%20petici%C3%B3n%20popular%20he%20creado%20un%20%C3%BAltimo%20screencast%20sobre%20CodeIgniter.%20En%20%C3%A9l%20os%20voy%20a%20ense%C3%B1ar%20un%20par%20de%20conceptos%20importantes%20para%20extender%20la%20funcionalidad%20del%20framework%3A%20los%20hooks%20y%20la%20creaci%C3%B3n%20de%20librerias.%20Como%20ejemplo%20crear%C3%A9%20un%20sistema%20muy%20s" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;t=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;title=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter&amp;annotation=A%20petici%C3%B3n%20popular%20he%20creado%20un%20%C3%BAltimo%20screencast%20sobre%20CodeIgniter.%20En%20%C3%A9l%20os%20voy%20a%20ense%C3%B1ar%20un%20par%20de%20conceptos%20importantes%20para%20extender%20la%20funcionalidad%20del%20framework%3A%20los%20hooks%20y%20la%20creaci%C3%B3n%20de%20librerias.%20Como%20ejemplo%20crear%C3%A9%20un%20sistema%20muy%20s" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;title=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F&amp;t=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter&amp;s=A%20petici%C3%B3n%20popular%20he%20creado%20un%20%C3%BAltimo%20screencast%20sobre%20CodeIgniter.%20En%20%C3%A9l%20os%20voy%20a%20ense%C3%B1ar%20un%20par%20de%20conceptos%20importantes%20para%20extender%20la%20funcionalidad%20del%20framework%3A%20los%20hooks%20y%20la%20creaci%C3%B3n%20de%20librerias.%20Como%20ejemplo%20crear%C3%A9%20un%20sistema%20muy%20s" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Videotutorial%3A%20Hooks%20y%20creaci%C3%B3n%20de%20librer%C3%ADas%20con%20Codeigniter%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdesarrollo-web%2Fscreencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/screencast-tutorial-hooks-y-creacion-de-librerias-con-codeigniter/feed/</wfw:commentRss>
		<slash:comments>62</slash:comments>
		</item>
		<item>
		<title>Fuentes en la web con @font-face</title>
		<link>http://www.davidrojas.net/index.php/diseno-web/fuentes-en-la-web-con-font-face/</link>
		<comments>http://www.davidrojas.net/index.php/diseno-web/fuentes-en-la-web-con-font-face/#comments</comments>
		<pubDate>Mon, 21 Dec 2009 20:59:19 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Desarrollo Web]]></category>
		<category><![CDATA[Diseño Web]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=541</guid>
		<description><![CDATA[Una de las grandes limitaciones que siempre hemos tenido diseñando en la web ha sido la incapacidad de poder usar fuentes mas allá de las que el usuario tiene instaladas por defecto en su sistema. Por ello las opciones que teníamos era utilizar imágenes (sólo recomendable para encabezados y menús) y las clásicas fuentes Arial, [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2009/12/font-face_img.png" alt="" title="font-face_img" width="163" height="104" class="derecha alignright size-full wp-image-563" />Una de las grandes limitaciones que siempre hemos tenido diseñando en la web ha sido la incapacidad de poder usar fuentes mas allá de las que el usuario tiene instaladas por defecto en su sistema. Por ello las opciones que teníamos era utilizar imágenes (sólo recomendable para encabezados y menús) y las clásicas fuentes Arial, Verdana, Georgia, &#8230;etc., las llamadas fuentes &#8220;web-safe&#8221; que sabemos se encuentran en la mayoría de los sistemas. Recientemente han salido herramientas como Cufón y Typekit, que nos permiten mostrar fuentes usando javascript, pero estos sistemas no son la solución más óptima.</p>
<p>Hoy día gracias al avance de los navegadores podemos usar cualquier fuente utilizando la propiedad CSS <em>@font-face</em>, siempre que tengamos en cuenta y respetemos la licencia de cada una, que debe permitir empotrado mediante @font-face. Podemos ver un listado de fuentes y licencias que permiten este uso en <a href="http://webfonts.info/wiki/index.php?title=Fonts_available_for_%40font-face_embedding" title ="Fonts availabe for @font-face embedding">el wiki de webfonts.info</a>.<br />
A continuación os explicaré cómo utilizar @font-face para poder usar fuentes de verdad en la web.<br />
<span id="more-541"></span></p>
<h3>La forma fácil</h3>
<p>La forma más sencilla es utilizar el <a href="http://www.fontsquirrel.com/fontface/generator">generador de fontsquirrel</a>. Simplemente tenemos que subir la fuente que queramos utilizar, marcar los formatos EOT, SVG y WOFF, y nos descargaremos un paquete que contiene nuestra fuente en los distintos formatos y un ejemplo con el código CSS para hacerlo funcionar.</p>
<h3>Explicación del CSS. ¿Por qué tantos formatos?</h3>
<p>Echemos un vistazo al css para poder usar la fuente Quicksand Light:</p>

<div class="wp_syntax"><div class="code"><pre class="css" style="font-family:monospace;"><span style="color: #a1a100;">@font-face {</span>
   <span style="color: #000000; font-weight: bold;">font-family</span><span style="color: #00AA00;">:</span> <span style="color: #ff0000;">'QuicksandLight'</span><span style="color: #00AA00;">;</span>
   src<span style="color: #00AA00;">:</span> <span style="color: #993333;">url</span><span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'Quicksand_Light.eot'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">;</span>
   src<span style="color: #00AA00;">:</span> local<span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'Quicksand Light'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">,</span> local<span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'QuicksandLight-Regular'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">,</span> 
   <span style="color: #993333;">url</span><span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'Quicksand_Light.woff'</span><span style="color: #00AA00;">&#41;</span> format<span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'woff'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">,</span> 
   <span style="color: #993333;">url</span><span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'Quicksand_Light.otf'</span><span style="color: #00AA00;">&#41;</span> format<span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'opentype'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">,</span> 
   <span style="color: #993333;">url</span><span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'Quicksand_Light.svg#QuicksandLight-Regular'</span><span style="color: #00AA00;">&#41;</span> format<span style="color: #00AA00;">&#40;</span><span style="color: #ff0000;">'svg'</span><span style="color: #00AA00;">&#41;</span><span style="color: #00AA00;">;</span>
<span style="color: #00AA00;">&#125;</span>
h1<span style="color: #00AA00;">&#123;</span><span style="color: #000000; font-weight: bold;">font</span><span style="color: #00AA00;">:</span> <span style="color: #933;">60px</span>/<span style="color: #933;">68px</span> <span style="color: #ff0000;">'QuicksandLight'</span><span style="color: #00AA00;">,</span> Arial<span style="color: #00AA00;">,</span> <span style="color: #993333;">sans-serif</span><span style="color: #00AA00;">;</span><span style="color: #00AA00;">&#125;</span></pre></div></div>

<p>En primer lugar definimos el nombre de la fuente con <em>font-family</em>. Este nombre es el que usaremos cuando asignemos dicha fuente mediante la propiedad </em>font</em>, en este ejemplo al <em>h1</em>. Después se debe poner inmediatamente el src con la versión <em>EOT</em>, que es el formato utilizado por Internet Explorer. De esta manera IE descargará y utilizará este formato, y no seguirá buscando los siguientes ya que no reconoce el valor <em>local()</em> del segundo src.<br />
El resto de navegadores ignorarán el EOT y probarán los siguientes formatos hasta que encuentren uno que funcione en ellos. WOFF es el nuevo formato que será soportado por Firefox 3.6 y apunta a ser el futuro en los formatos de fuentes empotradas, así que no está de mas incluirlo. Firefox 3.5, Safari, Opera y Chrome 4 usarán el fichero OTF o TTF.<br />
El formato SVG es necesario para versiones antiguas de Chrome y Safari para iPhone.<br />
Después solo nos queda añadir la propiedad <em>font</em> a los elementos que queramos, sin olvidarnos de añadir otras fuentes web-safe por si algo falla (en este caso Arial y sans-serif).</p>
<p>Aquí podemos ver una <a href="http://www.fontsquirrel.com/fontfacedemo/Quicksand" title="Fuente Quicksand usando @font-face">una demo utilizando la fuente Quicksand</a>.</p>
<p>Finalmente, si no queremos pasar por el proceso de buscar una fuente con licencia empotrable y convertirla, podemos utilizar los <a href="http://www.fontsquirrel.com/fontface" title="Kits font-face">kits de fontsquirrel</a>, entre los que tenemos una amplia selección de fuentes preparadas para descargar en paquetes que contienen todos los formatos necesarios, con un fichero html y css de ejemplo de uso.</p>

<div class="sociable">
<div class="sociable_tagline">
<em>Si te ha gustado este artículo, por favor compártelo:</em>
</div>
<ul>
	<li class="sociablefirst"><a rel="nofollow"  target="_blank" href="http://www.printfriendly.com/print?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;partner=sociable" title="Print"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/printfriendly.png" title="Print" alt="Print" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://digg.com/submit?phase=2&amp;url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;title=Fuentes%20en%20la%20web%20con%20%40font-face&amp;bodytext=Una%20de%20las%20grandes%20limitaciones%20que%20siempre%20hemos%20tenido%20dise%C3%B1ando%20en%20la%20web%20ha%20sido%20la%20incapacidad%20de%20poder%20usar%20fuentes%20mas%20all%C3%A1%20de%20las%20que%20el%20usuario%20tiene%20instaladas%20por%20defecto%20en%20su%20sistema.%20Por%20ello%20las%20opciones%20que%20ten%C3%ADamos%20era%20utilizar%20im" title="Digg"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/digg.png" title="Digg" alt="Digg" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://delicious.com/post?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;title=Fuentes%20en%20la%20web%20con%20%40font-face&amp;notes=Una%20de%20las%20grandes%20limitaciones%20que%20siempre%20hemos%20tenido%20dise%C3%B1ando%20en%20la%20web%20ha%20sido%20la%20incapacidad%20de%20poder%20usar%20fuentes%20mas%20all%C3%A1%20de%20las%20que%20el%20usuario%20tiene%20instaladas%20por%20defecto%20en%20su%20sistema.%20Por%20ello%20las%20opciones%20que%20ten%C3%ADamos%20era%20utilizar%20im" title="del.icio.us"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/delicious.png" title="del.icio.us" alt="del.icio.us" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.facebook.com/share.php?u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;t=Fuentes%20en%20la%20web%20con%20%40font-face" title="Facebook"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/facebook.png" title="Facebook" alt="Facebook" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.google.com/bookmarks/mark?op=edit&amp;bkmk=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;title=Fuentes%20en%20la%20web%20con%20%40font-face&amp;annotation=Una%20de%20las%20grandes%20limitaciones%20que%20siempre%20hemos%20tenido%20dise%C3%B1ando%20en%20la%20web%20ha%20sido%20la%20incapacidad%20de%20poder%20usar%20fuentes%20mas%20all%C3%A1%20de%20las%20que%20el%20usuario%20tiene%20instaladas%20por%20defecto%20en%20su%20sistema.%20Por%20ello%20las%20opciones%20que%20ten%C3%ADamos%20era%20utilizar%20im" title="Google Bookmarks"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/googlebookmark.png" title="Google Bookmarks" alt="Google Bookmarks" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="mailto:?subject=Fuentes%20en%20la%20web%20con%20%40font-face&amp;body=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F" title="email"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/email_link.png" title="email" alt="email" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://meneame.net/submit.php?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F" title="Meneame"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/meneame.png" title="Meneame" alt="Meneame" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.stumbleupon.com/submit?url=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;title=Fuentes%20en%20la%20web%20con%20%40font-face" title="StumbleUpon"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/stumbleupon.png" title="StumbleUpon" alt="StumbleUpon" class="sociable-hovers" /></a></li>
	<li><a rel="nofollow"  target="_blank" href="http://www.tumblr.com/share?v=3&amp;u=http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F&amp;t=Fuentes%20en%20la%20web%20con%20%40font-face&amp;s=Una%20de%20las%20grandes%20limitaciones%20que%20siempre%20hemos%20tenido%20dise%C3%B1ando%20en%20la%20web%20ha%20sido%20la%20incapacidad%20de%20poder%20usar%20fuentes%20mas%20all%C3%A1%20de%20las%20que%20el%20usuario%20tiene%20instaladas%20por%20defecto%20en%20su%20sistema.%20Por%20ello%20las%20opciones%20que%20ten%C3%ADamos%20era%20utilizar%20im" title="Tumblr"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/tumblr.png" title="Tumblr" alt="Tumblr" class="sociable-hovers" /></a></li>
	<li class="sociablelast"><a rel="nofollow"  target="_blank" href="http://twitter.com/home?status=Fuentes%20en%20la%20web%20con%20%40font-face%20-%20http%3A%2F%2Fwww.davidrojas.net%2Findex.php%2Fdiseno-web%2Ffuentes-en-la-web-con-font-face%2F" title="Twitter"><img src="http://www.davidrojas.net/wp-content/plugins/sociable/images/twitter.png" title="Twitter" alt="Twitter" class="sociable-hovers" /></a></li>
</ul>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/diseno-web/fuentes-en-la-web-con-font-face/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
	</channel>
</rss>
