<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rss 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/" version="2.0">

<channel>
	<title>David Rojas</title>
	
	<link>http://www.davidrojas.net</link>
	<description>Diseño y desarrollo web</description>
	<lastBuildDate>Thu, 07 Apr 2011 19:33:00 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.feedburner.com/DavidRojas" /><feedburner:info xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" uri="davidrojas" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><feedburner:emailServiceId xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0">DavidRojas</feedburner:emailServiceId><feedburner:feedburnerHostname xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0">http://feedburner.google.com</feedburner:feedburnerHostname><item>
		<title>Publicado CodeIgniter 2.0</title>
		<link>http://www.davidrojas.net/index.php/codeigniter/publicado-codeigniter-2-0/</link>
		<comments>http://www.davidrojas.net/index.php/codeigniter/publicado-codeigniter-2-0/#comments</comments>
		<pubDate>Fri, 28 Jan 2011 21:45:34 +0000</pubDate>
		<dc:creator>David Rojas</dc:creator>
				<category><![CDATA[CodeIgniter]]></category>

		<guid isPermaLink="false">http://www.davidrojas.net/?p=896</guid>
		<description><![CDATA[Acaba de publicarse la esperada versión 2.0 de CodeIgniter. Para los que no hayan estado siguiendo su desarrollo, debido a ciertas disputas entre los miembros de la comunidad y los desarrolladores, motivadas principalmente por la lentitud en la incorporación de nuevas funcionalidades y los retrasos en la publicación de versiones, se decidió por parte de [...]]]></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" />Acaba de publicarse la esperada versión 2.0 de <a href="http://codeigniter.com/download.php">CodeIgniter</a>. Para los que no hayan estado siguiendo su desarrollo, debido a ciertas disputas entre los miembros de la comunidad y los desarrolladores, motivadas principalmente por la lentitud en la incorporación de nuevas funcionalidades y los retrasos en la publicación de versiones, se decidió por parte de Ellislab (la empresa que desarrolla CodeIgniter) separar CodeIgniter en dos ramas: <em>Core</em> y <em>Reactor</em>.</p>
<p>La versión <em>Core</em>, será de desarrollo más lento, y es la que usará Ellislab en sus productos comerciales.</p>
<p><em>Reactor</em> será la versión &#8220;community&#8221;, en la que los usuarios podrán enviar sus propuestas de mejora, y un equipo de responsables del proyecto las revisará para ser incluidas o no en futuras versiones del framework. </p>
<p>A todos los efectos, la versión a usar es la <em>Reactor</em>. Ésta es la que aparece oficialmente para descarga en la web (aunque ambas están disponibles) y la que Ellislab recomienda.<br />
<span id="more-896"></span><br />
Algunos de los cambios más importantes son:</p>
<ul class="bullets">
<li>Se ha eliminado la compatibilidad con PHP 4, ahora se requiere PHP 5.1</li>
<li>Añadida la protección CSRF en el <a href="http://codeigniter.com/user_guide/helpers/form_helper.html">form helper</a>.</li>
<li><a href="http://codeigniter.com/user_guide/general/drivers.html">Drivers</a>.</li>
<li><a href="http://codeigniter.com/user_guide/libraries/loader.html">Application packages</a>.</li>
<li>Se ha eliminado el uso de los plugins, en favor de los helpers.</li>
<li>Añadido <em>$route[‘404_override’]</em> para permitir manejar las páginas de error 404 por los controladores.</li>
<li>Se ha eliminado el <em>scaffolding</em>.</li>
<li>Soporte total de <a href="http://codeigniter.com/user_guide/general/urls.html">query strings</a>.</li>
<li>Nuevo sistema de <a href="http://codeigniter.com/user_guide/libraries/caching.html">caché</a>, con soporte para APC y memcache.</li>
<li>Compatibilidad con línea de comandos, para facilitar el uso del cron.</li>
</ul>
<p>Se ha quedado fuera la inclusión de una librería de autenticación, que era una de las características más demandadas y a mi parecer muy necesaria, pero parece ser que está planeado y se incluirá en futuras versiones cuando se encuentre la manera correcta de implementarlo.</p>
<p>Podeis ver <a href="http://codeigniter.com/news/codeigniter_2.0.0_released/">el anuncio oficial de Ellislab</a>, y <a href="http://codeigniter.com/downloads/">descargarlo aquí</a>.</p>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/M6fguxBQ8h4" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/codeigniter/publicado-codeigniter-2-0/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Diseños flexibles con CSS3 media queries</title>
		<link>http://www.davidrojas.net/index.php/diseno-web/videotutorial-disenos-flexibles-con-css3-media-queries/</link>
		<comments>http://www.davidrojas.net/index.php/diseno-web/videotutorial-disenos-flexibles-con-css3-media-queries/#comments</comments>
		<pubDate>Tue, 19 Oct 2010 19:29:06 +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=851</guid>
		<description><![CDATA[Con la llegada de los tablets y el aumento de uso de los smartphones con distintas resoluciones y tamaños de pantalla, nos surge el problema de crear versiones móviles diferentes para cada dispositivo. CSS3 nos trae una nueva herramienta para atacar este problema: los media queries. El funcionamiento de los media queries consiste en disponer [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://www.davidrojas.net/wp-content/uploads/2010/10/screencast_media_queries.png" alt="" width="163" height="104" class="derecha alignright size-full wp-image-866" /></a>Con la llegada de los tablets y el aumento de uso de los smartphones con distintas resoluciones y tamaños de pantalla, nos surge el problema de crear versiones móviles diferentes para cada dispositivo.</p>
<p>CSS3 nos trae una nueva herramienta para atacar este problema: los <em><a href="http://www.w3.org/TR/css3-mediaqueries/" title="CSS3 media queries">media queries</a></em>. El funcionamiento de los media queries consiste en disponer de un único documento html para todas las versiones, y seleccionar una u otra hoja de estilo CSS dependiendo de algunos parámetros del dispositivo, principalmente la resolución de la pantalla. De esta manera eliminamos la necesidad de redireccionar a una versión móvil diferente de nuestro sitio, sino que cada dispositivo leerá un bloque de reglas CSS según su anchura.</p>
<p>En este videotutorial voy a enseñaros cómo utilizar los media queries mediante un sencillo ejemplo de diseño de tres columnas de contenido y un menú. Veremos cómo las columnas se reordenan según disminuimos el tamaño del navegador, y por lo tanto cómo se mostraría en dispositivos de ese tamaño.</p>
<p><em class="linkem"><a href='http://www.davidrojas.net/demos/media_queries/' title="Demo mejora con CSS3" target="_blank">Ver Demo CSS3 media queries</a></em><br />
<span id="more-851"></span></p>
<h3>Ver screencast (duración: 8:03)</h3>
<div class="video">
<embed src="http://blip.tv/play/hJIhgoW7dAA" 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-12DiseosFlexiblesConCSS3MediaQueries693.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-12DiseosFlexiblesConCSS3MediaQueries502.m4v" title="Descargar versión iPod/iPhone">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (18 MB)</a></li>
</ul>
<p></p>
<p>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>
<p>Aunque en el video no lo menciono, en lugar de definir los estilos dentro de los bloques <em>@media</em>, también podemos separarlos en distintas hojas de estilo y enlazarlos cambiando el atributo media, por ejemplo:</p>

<div class="wp_syntax"><div class="code"><pre class="css" style="font-family:monospace;">&lt;link rel<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;stylesheet&quot;</span> href<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;principal.css&quot;</span> type<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;text/css&quot;</span> media<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;screen&quot;</span> /<span style="color: #00AA00;">&gt;</span>
&lt;link rel<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;stylesheet&quot;</span> href<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;iphone_version.css&quot;</span> type<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;text/css&quot;</span> media<span style="color: #00AA00;">=</span><span style="color: #ff0000;">&quot;screen and (max-width: 480px)&quot;</span> /<span style="color: #00AA00;">&gt;</span></pre></div></div>

<p>Si os interesa el tema os recomiendo leer este artículo de <em>A List Apart</em>: <a href="http://www.alistapart.com/articles/responsive-web-design/" title="Responsive Web Design - A List Apart">Responsive Web Design</a>.</p>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/H8T02tLMK-Y" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/diseno-web/videotutorial-disenos-flexibles-con-css3-media-queries/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Videotutorial – Patrones de diseño en PHP – 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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/ftTnCZV8XXU" height="1" width="1"/>]]></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>3</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP – 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>
	<span style="color: #000000; font-weight: bold;">protected</span> <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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/eh78fguE9TU" height="1" width="1"/>]]></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>9</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP – 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>
	<span style="color: #000000; font-weight: bold;">protected</span> <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>
	<span style="color: #000000; font-weight: bold;">protected</span> <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>
	<span style="color: #000000; font-weight: bold;">protected</span> <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>
			<span style="color: #b1b100;">throw</span> <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>

<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/7XKOMP1LZwg" height="1" width="1"/>]]></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>15</slash:comments>
		</item>
		<item>
		<title>Videotutorial: Patrones de diseño en PHP – 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 class="derecha alignright size-full wp-image-774" title="screencast_php_patterns" src="http://www.davidrojas.net/wp-content/uploads/2010/03/screencast_php_patterns.png" alt="" width="163" height="104" />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 type="application/x-shockwave-flash" width="490" height="397" src="http://blip.tv/play/hJIhgdHaMAA" allowfullscreen="true" allowscriptaccess="always"></embed></div>
<ul>
<li><a title="Descargar versión alta calidad" href="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern307.mov">Descargar videotutorial en alta calidad &#8211; MOV (12 MB)</a></li>
<li><a title="Descargar versión iPod/iPhone" href="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern667.m4v">Descargar videotutorial optimizado para iPod/iPhone &#8211; M4V (7 MB)</a></li>
</ul>
<p>&nbsp;</p>
<p>Podéis ver el resto de screencasts en la <a title="Videotutoriales de diseño, desarrollo web, codeigniter, CSS3" href="http://www.davidrojas.net/index.php/category/screencasts/">página de videotutoriales</a>, o suscribiros al <a title="Enlace a videopodcast de David Rojas en iTunes" href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewPodcast?id=326994250">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>
<p>Relacionados:</p>
<ul>
<li><a title="Videotutorial: Patrones de diseño en PHP – Factory Pattern" href="http://www.davidrojas.net/index.php/desarrollo-web/screencast-patrones-de-diseno-en-php-factory-pattern/">Videotutorial: Patrones de diseño en PHP – Factory Pattern</a></li>
<li><a title="Videotutorial: Patrones de diseño en PHP – Observer Pattern" href="http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-observer-pattern/">Videotutorial: Patrones de diseño en PHP – Observer Pattern</a></li>
<li><a title="Videotutorial: Patrones de diseño en PHP – Chain-of-command" href="http://www.davidrojas.net/index.php/desarrollo-web/videotutorial-patrones-de-diseno-en-php-chain-of-command/">Videotutorial: Patrones de diseño en PHP – Chain-of-command Pattern</a></li>
</ul>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/XzhG7yF1fKc" height="1" width="1"/>]]></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>12</slash:comments>
<enclosure url="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern307.mov" length="12862046" type="video/quicktime" />
<enclosure url="http://blip.tv/file/get/Davidrojas-8PatronesDeDiseoEnPHPSingletonPattern667.m4v" length="7233505" type="video/mp4" />
		</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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/fgaf8mWwkpk" height="1" width="1"/>]]></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 – 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[jQuery]]></category>
		<category><![CDATA[Screencasts]]></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 [...]]]></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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/swQxDkC41pQ" height="1" width="1"/>]]></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>54</slash:comments>
		</item>
		<item>
		<title>URLs amigables en CodeIgniter: Controlador ‘catch-all’</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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/sLwuBq3B-Js" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/desarrollo-web/urls-amigables-en-codeigniter-controlador-catch-all/feed/</wfw:commentRss>
		<slash:comments>29</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>
<img src="http://feeds.feedburner.com/~r/DavidRojas/~4/6NFhFSSUrVQ" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://www.davidrojas.net/index.php/diseno-web/screencast-mejora-progresiva-con-css3/feed/</wfw:commentRss>
		<slash:comments>11</slash:comments>
		</item>
	</channel>
</rss>

