<?xml version='1.0' encoding='UTF-8'?><?xml-stylesheet href="http://www.blogger.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:georss='http://www.georss.org/georss' xmlns:gd='http://schemas.google.com/g/2005' xmlns:thr='http://purl.org/syndication/thread/1.0'><id>tag:blogger.com,1999:blog-4707043337444828210</id><updated>2011-11-27T18:20:45.201-05:00</updated><category term='dns secondary'/><category term='flash'/><category term='comportamiento'/><category term='red'/><category term='entorno de red'/><category term='tarjeta de red'/><category term='javascript'/><category term='campos'/><category term='archivo .bat'/><category term='formularios'/><category term='línea de comandos'/><category term='modificar'/><category term='validation'/><category term='puerta de enlace'/><category term='dhtml'/><category term='library'/><category term='dirección ip'/><category term='Greasemonkey'/><category term='en linea'/><category term='máscara de subred'/><category term='dns primario'/><category term='dns secundario'/><category term='Webshots'/><category term='Downloader'/><category term='html'/><category term='script'/><category term='livevalidation'/><category term='on line'/><category term='validacion'/><category term='deseado'/><category term='ocultar'/><category term='libreria'/><category term='menu'/><category term='dns primary'/><title type='text'>Notas de Programación</title><subtitle type='html'>Notas de programación de temas que ocurren todos los días y para las cuales encontramos soluciones creativas y que pueden servir a otros con las mismas o similares preocupaciones</subtitle><link rel='http://schemas.google.com/g/2005#feed' type='application/atom+xml' href='http://notasprogramacion.blogspot.com/feeds/posts/default'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default?max-results=100'/><link rel='alternate' type='text/html' href='http://notasprogramacion.blogspot.com/'/><link rel='hub' href='http://pubsubhubbub.appspot.com/'/><author><name>Jairo Bernal</name><uri>http://www.blogger.com/profile/02203494720229682531</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='http://img2.blogblog.com/img/b16-rounded.gif'/></author><generator version='7.00' uri='http://www.blogger.com'>Blogger</generator><openSearch:totalResults>4</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>100</openSearch:itemsPerPage><entry><id>tag:blogger.com,1999:blog-4707043337444828210.post-5300346458553097170</id><published>2009-09-14T23:24:00.003-05:00</published><updated>2009-09-14T23:46:22.529-05:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='dhtml'/><category scheme='http://www.blogger.com/atom/ns#' term='deseado'/><category scheme='http://www.blogger.com/atom/ns#' term='ocultar'/><category scheme='http://www.blogger.com/atom/ns#' term='comportamiento'/><category scheme='http://www.blogger.com/atom/ns#' term='flash'/><category scheme='http://www.blogger.com/atom/ns#' term='menu'/><title type='text'>Comportamiento no deseado de flash con menús DHTML dinámicos</title><content type='html'>Tuve problemas con un sitio que estaba diseñando y en el cual se coloca una presentación flash. El problema ocurrió porque el sitio tiene un menú que está desarrollado en dhtml, cuando el usuario mueve el cursor sobre el menú se despliegan submenús con otras opciones, pero lamentablemente el flash quedaba por encima de los menús y ocultaba el contenido de estos.&lt;br /&gt;La solución es bastante sencilla, basta con colocar la presentación flash dentro de un div con las siguientes características:&lt;br /&gt;&lt;br /&gt;&lt;pre&gt;&lt;span style="color:#2040a0;"&gt;&lt;strong&gt;&lt;span style="color:#4444ff;"&gt;&lt;strong&gt;&amp;lt;&lt;/strong&gt;&lt;/span&gt;&lt;span style="color:#2040a0;"&gt;div&lt;/span&gt; &lt;span style="color:#2040a0;"&gt;style=&lt;/span&gt;&lt;span style="color:#008000;"&gt;"z-index: 0;"&lt;/span&gt;&lt;span style="color:#4444ff;"&gt;&lt;strong&gt;&amp;gt;&lt;/strong&gt;&lt;/span&gt;&lt;/strong&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="color:#444444;"&gt;&amp;lt;!-- Aquí va el código de la presentación flash --&amp;gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="color:#2040a0;"&gt;&lt;strong&gt;&lt;span style="color:#4444ff;"&gt;&lt;strong&gt;&amp;lt;&lt;/strong&gt;&lt;/span&gt;&lt;span style="color:#2040a0;"&gt;/div&lt;/span&gt;&lt;span style="color:#4444ff;"&gt;&lt;strong&gt;&amp;gt;&lt;/strong&gt;&lt;/span&gt;&lt;/strong&gt;&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;&lt;/pre&gt;Y listo, ahora los menús aparecerán sobre la presentación flash. Fácil, sencillo y efectivo.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4707043337444828210-5300346458553097170?l=notasprogramacion.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://notasprogramacion.blogspot.com/feeds/5300346458553097170/comments/default' title='Enviar comentarios'/><link rel='replies' type='text/html' href='http://www.blogger.com/comment.g?blogID=4707043337444828210&amp;postID=5300346458553097170' title='0 comentarios'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/5300346458553097170'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/5300346458553097170'/><link rel='alternate' type='text/html' href='http://notasprogramacion.blogspot.com/2009/09/comportamiento-no-deseado-de-flash-con.html' title='Comportamiento no deseado de flash con menús DHTML dinámicos'/><author><name>Jairo Bernal</name><uri>http://www.blogger.com/profile/02203494720229682531</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='http://img2.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-4707043337444828210.post-1606626639611384590</id><published>2009-08-23T21:41:00.011-05:00</published><updated>2009-08-27T00:05:14.047-05:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='javascript'/><category scheme='http://www.blogger.com/atom/ns#' term='on line'/><category scheme='http://www.blogger.com/atom/ns#' term='en linea'/><category scheme='http://www.blogger.com/atom/ns#' term='library'/><category scheme='http://www.blogger.com/atom/ns#' term='validacion'/><category scheme='http://www.blogger.com/atom/ns#' term='campos'/><category scheme='http://www.blogger.com/atom/ns#' term='libreria'/><category scheme='http://www.blogger.com/atom/ns#' term='livevalidation'/><category scheme='http://www.blogger.com/atom/ns#' term='validation'/><category scheme='http://www.blogger.com/atom/ns#' term='html'/><category scheme='http://www.blogger.com/atom/ns#' term='formularios'/><title type='text'>Modificación de la librería livevalidation.js</title><content type='html'>Para un proyecto de sitio web necesité una librería de validación de envío de formularios, uno de los requisitos del cliente era que la validación se hiciera tan pronto como el usuario estuviera digitando el formulario. Estuve buscando en la red y me encontré con una muy buena librería que hace esto, la dirección es:&lt;br /&gt;&lt;a href="http://www.livevalidation.com/"&gt;http://www.livevalidation.com/&lt;/a&gt;&lt;br /&gt;Me pareció espectacular, sólo encontré una dificultad y es que yo quería poder colocar imágenes o código html en los mensajes de validación, concretamente colocar &lt;img style="cursor: pointer; width: 16px; height: 16px;" src="http://1.bp.blogspot.com/_Iw190QvnFxc/SouMvT0O_4I/AAAAAAAAAzE/s0F-Bjq_SMg/s320/check.png" alt="" id="ImagenMensajeOK" border="0" /&gt; para un mensaje de validado y &lt;img style="cursor: pointer; width: 16px; height: 16px;" src="http://2.bp.blogspot.com/_Iw190QvnFxc/SouU_lEiGJI/AAAAAAAAAzM/2nrLw6emy6o/s320/error.png" alt="" id="BLOGGER_PHOTO_ID_5371550800573241490" border="0" /&gt; para un mensaje de error.&lt;br /&gt;Si revisamos el código fuente de la librería encontramos que está bajo licencia MIT que expresamente dice:&lt;br /&gt;&lt;code&gt;&lt;br /&gt;/****************** MIT License **********************/&lt;br /&gt;/**&lt;br /&gt;*  Permission is hereby granted, free of charge, to any person&lt;br /&gt;*  obtaining a copy of this software and associated&lt;br /&gt;*  documentation files (the “Software”), to deal in the Software&lt;br /&gt;*  without restriction, including without limitation the rights&lt;br /&gt;*  to use, copy, modify, merge, publish, distribute, sublicense,&lt;br /&gt;*  and/or sell copies of the Software, and to permit persons to &lt;br /&gt;*  whom the Software is furnished to do so, subject to the &lt;br /&gt;*  following conditions:&lt;br /&gt;*&lt;br /&gt;*  The above copyright notice and this permission notice shall &lt;br /&gt;*  be included in all copies or substantial portions of the &lt;br /&gt;*  Software.&lt;br /&gt;*&lt;br /&gt;*  THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF&lt;br /&gt;*  ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT&lt;br /&gt;*  LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS&lt;br /&gt;*  FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.&lt;br /&gt;*  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE&lt;br /&gt;*  LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, &lt;br /&gt;*  WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,&lt;br /&gt;*  ARISING FROM, OUT OF OR IN CONNECTION WITH THE&lt;br /&gt;*  SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.&lt;br /&gt;*/&lt;/code&gt;&lt;br /&gt;Aprovechando esto, podemos tomar el código y hacerle las modificaciones que necesitemos, así que hice precisamente eso:&lt;br /&gt;El resultado lo pueden descargar de &lt;a href="http://sites.google.com/site/blogsprogramacion/testLiveValidation.zip"&gt;aquí&lt;/a&gt;&lt;br /&gt;El archivo se debe descomprimir y colocar en un sitio web para pruebas.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4707043337444828210-1606626639611384590?l=notasprogramacion.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://notasprogramacion.blogspot.com/feeds/1606626639611384590/comments/default' title='Enviar comentarios'/><link rel='replies' type='text/html' href='http://www.blogger.com/comment.g?blogID=4707043337444828210&amp;postID=1606626639611384590' title='0 comentarios'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/1606626639611384590'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/1606626639611384590'/><link rel='alternate' type='text/html' href='http://notasprogramacion.blogspot.com/2009/08/modificacion-de-la-libreria.html' title='Modificación de la librería livevalidation.js'/><author><name>Jairo Bernal</name><uri>http://www.blogger.com/profile/02203494720229682531</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='http://img2.blogblog.com/img/b16-rounded.gif'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://1.bp.blogspot.com/_Iw190QvnFxc/SouMvT0O_4I/AAAAAAAAAzE/s0F-Bjq_SMg/s72-c/check.png' height='72' width='72'/><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-4707043337444828210.post-7529234013695972548</id><published>2009-08-18T11:34:00.010-05:00</published><updated>2009-08-23T21:38:24.531-05:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='dns primario'/><category scheme='http://www.blogger.com/atom/ns#' term='línea de comandos'/><category scheme='http://www.blogger.com/atom/ns#' term='dns secundario'/><category scheme='http://www.blogger.com/atom/ns#' term='entorno de red'/><category scheme='http://www.blogger.com/atom/ns#' term='máscara de subred'/><category scheme='http://www.blogger.com/atom/ns#' term='dns primary'/><category scheme='http://www.blogger.com/atom/ns#' term='archivo .bat'/><category scheme='http://www.blogger.com/atom/ns#' term='dns secondary'/><category scheme='http://www.blogger.com/atom/ns#' term='tarjeta de red'/><category scheme='http://www.blogger.com/atom/ns#' term='puerta de enlace'/><category scheme='http://www.blogger.com/atom/ns#' term='modificar'/><category scheme='http://www.blogger.com/atom/ns#' term='red'/><category scheme='http://www.blogger.com/atom/ns#' term='dirección ip'/><title type='text'>Cambiar la configuración de una tarjeta de red desde una línea de comandos en Windows</title><content type='html'>De manera frecuente ocurre que necesitamos configurar la tarjeta de red en entornos de red diferentes. En estos casos es bastante dispendioso volver a entrar a la configuración de la tarjeta de red y escribir los valores de dirección ip, máscara de subred, puerta de enlace, dns primario y dns secundario. Para evitar esto se puede hacer un archivo .bat con los comandos que cambian la configuración de red de la tarjeta de red. Por ejemplo:&lt;br /&gt;&lt;code&gt;REM Inicio de archivo bat&lt;br /&gt;@echo off&lt;br /&gt;netsh interface ip set address name="Nombre de la conexión de red" static [Direccion IP] [Mascara de red] [Puerta de enlace] 1&lt;br /&gt;netsh interface ip set dns "Nombre de la conexión de red" static [IP DNS Primario] primary&lt;br /&gt;netsh interface ip add dns "Nombre de la conexión de red" [IP DNS Secundario]&lt;br /&gt;ipconfig /release&lt;br /&gt;ipconfig /renew&lt;br /&gt;REM Fin de archivo bat&lt;br /&gt;&lt;/code&gt;&lt;br /&gt;Guardamos el archivo con extensión .bat y lo podemos colocar en el escritorio, así cuando queramos modificar la configuración de la tarjeta de red lo que hacemos es dar doble clik y ya está. En Windows Vista hay que dar click con el botón derecho y seleccionar la opción de ejecutar como administrador. Un ejemplo completo sería el siguiente:&lt;br /&gt;&lt;code&gt;REM Inicio de archivo bat&lt;br /&gt;@echo off&lt;br /&gt;netsh interface ip set address name="Conexi¢n de rea local" static 192.168.25.133 255.255.255.0 192.168.25.12 1&lt;br /&gt;netsh interface ip set dns "Conexi¢n de rea local" static 192.168.1.1 primary&lt;br /&gt;netsh interface ip add dns "Conexi¢n de rea local" 192.168.1.10&lt;br /&gt;ipconfig /release&lt;br /&gt;ipconfig /renew&lt;br /&gt;REM Fin de archivo bat&lt;br /&gt;&lt;/code&gt;&lt;br /&gt;Esto valdría para una conexión de red que se llame "Conexión de área local", como ven hay que tener cuidado pues el manejo de las tildes no es igual en entornos Windows que en el entorno de línea de comandos, lo ideal sería no tener tildes en el nombre de las conexiones de red pero coloco el ejemplo así pues es la forma como Windows coloca el nombre por defecto cuando el sistema operativo está en español. En el ejemplo además la dirección IP fija que estamos asignado es la 192.168.25.133, la máscara de red 255.255.255.0, la puerta de enlace 192.168.25.12, el DNS primario 192.168.1.1 y el servidor DNS secundario 192.168.1.10.&lt;br /&gt;&lt;br /&gt;Sólo es cuestión de cambiar y colocar los valores que necesitamos y listo.&lt;br /&gt;&lt;br /&gt;El archivo de ejemplo lo pueden bajar de &lt;a href="http://jabernal.googlepages.com/ejemplotarjetared.bat"&gt;aquí&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4707043337444828210-7529234013695972548?l=notasprogramacion.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://notasprogramacion.blogspot.com/feeds/7529234013695972548/comments/default' title='Enviar comentarios'/><link rel='replies' type='text/html' href='http://www.blogger.com/comment.g?blogID=4707043337444828210&amp;postID=7529234013695972548' title='0 comentarios'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/7529234013695972548'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/7529234013695972548'/><link rel='alternate' type='text/html' href='http://notasprogramacion.blogspot.com/2009/08/cambiar-la-configuracion-de-una-tarjeta.html' title='Cambiar la configuración de una tarjeta de red desde una línea de comandos en Windows'/><author><name>Jairo Bernal</name><uri>http://www.blogger.com/profile/02203494720229682531</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='http://img2.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-4707043337444828210.post-8110459466318111456</id><published>2008-09-01T17:06:00.001-05:00</published><updated>2008-09-01T17:18:03.081-05:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='Downloader'/><category scheme='http://www.blogger.com/atom/ns#' term='Greasemonkey'/><category scheme='http://www.blogger.com/atom/ns#' term='Webshots'/><category scheme='http://www.blogger.com/atom/ns#' term='script'/><title type='text'>Webshots Downloader</title><content type='html'>He publicado un script &lt;a href="https://addons.mozilla.org/en/firefox/addon/748"&gt;GreaseMonkey&lt;/a&gt; para firefox que permite descargar imágenes desde &lt;a href="http://www.webshots.com/"&gt;Webshots&lt;/a&gt; sin necesidad de tener una cuenta Premium.&lt;br /&gt;&lt;br /&gt;&lt;a href="http://jabernal.googlepages.com/webshotsdownloader"&gt;Enlace al script&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4707043337444828210-8110459466318111456?l=notasprogramacion.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://notasprogramacion.blogspot.com/feeds/8110459466318111456/comments/default' title='Enviar comentarios'/><link rel='replies' type='text/html' href='http://www.blogger.com/comment.g?blogID=4707043337444828210&amp;postID=8110459466318111456' title='0 comentarios'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/8110459466318111456'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/4707043337444828210/posts/default/8110459466318111456'/><link rel='alternate' type='text/html' href='http://notasprogramacion.blogspot.com/2008/09/webshots-downloader.html' title='Webshots Downloader'/><author><name>Jairo Bernal</name><uri>http://www.blogger.com/profile/02203494720229682531</uri><email>noreply@blogger.com</email><gd:image rel='http://schemas.google.com/g/2005#thumbnail' width='16' height='16' src='http://img2.blogblog.com/img/b16-rounded.gif'/></author><thr:total>0</thr:total></entry></feed>
