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

<channel>
	<title>THLopes.com &#187; development</title>
	<atom:link href="http://www.thlopes.com/tag/development/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.thlopes.com</link>
	<description>Web, Ciência, Computação e Poesia</description>
	<lastBuildDate>Mon, 02 Jan 2012 20:29:16 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Republicando: jQuery, de olho nos gaps</title>
		<link>http://www.thlopes.com/2010/08/republicando-jquery-de-olho-nos-gaps/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=republicando-jquery-de-olho-nos-gaps</link>
		<comments>http://www.thlopes.com/2010/08/republicando-jquery-de-olho-nos-gaps/#comments</comments>
		<pubDate>Wed, 18 Aug 2010 00:54:50 +0000</pubDate>
		<dc:creator>Thomas Lopes</dc:creator>
				<category><![CDATA[Desenvolvimento]]></category>
		<category><![CDATA[tecnologia]]></category>
		<category><![CDATA[web]]></category>
		<category><![CDATA[ajax]]></category>
		<category><![CDATA[development]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[standards]]></category>

		<guid isPermaLink="false">http://www.thlopes.com/?p=902</guid>
		<description><![CDATA[Estou republicando esse artigo pois o mesmo recebeu um comentário, e ao mesmo tempo, é um assunto que ainda assola muitas pessoas que utilizam jQuery, principalmente quem começou com ela há pouco tempo. <a href="http://www.thlopes.com/2010/08/republicando-jquery-de-olho-nos-gaps/">Continuar lendo <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p><em>Estou republicando </em><a href="http://old.thlopes.com/content/view/141/46/"><em>esse artigo</em></a><em> pois o mesmo recebeu um comentário, e ao mesmo tempo, é um assunto que ainda assola muitas pessoas que utilizam </em><a href="http://docs.jquery.com"><em>jQuery</em></a><em>, principalmente quem começou com ela há pouco tempo.</em></p>
<p>Qual webdeveloper nunca usou <a class="bbli" href="http://sledge.boo-box.com/list/page/alF1ZXJ5XyMjX2JveF8jI190YWdnaW5nLXRvb2wtd3BfIyNfMjM5MzQ=-56">jQuery<img class="bbic" src="http://boo-box.com/bbli" alt="[bb]" /></a>? Muito difícil&#8230; Bom, mas vamos falar de algo que nem todos os <a class="bbli" href="http://sledge.boo-box.com/list/page/cHJvZ3JhbW1pbmdfIyNfYm94XyMjX3RhZ2dpbmctdG9vbC13cF8jI18yMzkzNA==-64">developers<img class="bbic" src="http://boo-box.com/bbli" alt="[bb]" /></a> que usam jQuery se atentam ao programar. Eu mesmo fui pego hoje por um gap que me tomou alguns minutos da tarde&#8230;</p>
<p>Algumas funções (na verdade, a maioria nesse framework) recebem outras funções como <em>callback</em>, aquela função que será chamada assim que a instrução/função chamada acabar seu procedimento. Um exemplo muito utilizado em aplicações reais são as</p>
<h2>Funções Ajax</h2>
<p style="background-color: #ffffff;padding: 2px;border: 1px solid #cccccc"><em>load</em>( url, data, <strong>callback </strong>)<br />
Returns: jQuery. Load HTML from a remote file and inject it into the DOM.</p>
<p style="background-color: #ffffff;padding: 2px;border: 1px solid #cccccc">jQuery.<em>get</em>( url, data, <strong>callback</strong>, type )<br />
Returns: XMLHttpRequest. Load a remote page using an HTTP GET request.</p>
<p style="background-color: #ffffff;padding: 2px;border: 1px solid #cccccc">jQuery.<em>getJSON</em>( url, data, <strong>callback </strong>)<br />
Returns: XMLHttpRequest. Load JSON data using an HTTP GET request.</p>
<p><span id="more-902"></span></p>
<p>Ao usar a função load, você carrega um arquivo remoto (seja ele html puro ou um arquivo dinâmico, como PHP ou outra linguagem), mas o tempo que ele leva para ser processado nem sempre é igual. E se você precisa esperar que o conteúdo seja totalmente carregado antes de proceder com o script?Colocar um timeout? No way, uma vez que você não tem controle sobre o tempo de execução em todas as plataformas e clientes&#8230; Logo, o Callback está aí para sanar essa questão.</p>
<h2>Porém&#8230;</h2>
<p>Temos que tomar cuidado ao usar o Callback, uma vez que o desempenho dos sistemas ainda podem afetar a funcionalidade de seu código, e fazer você perder várias horas de seu precioso descanso&#8230;Veja esse trecho de código que trabalhei recentemente:</p>
<pre>jQuery().ready(function() {
   jQuery.getJSON('/php/data.drafts.php?l=10&amp;f=json', function(data){
      jQuery.each(data, function(i, item){
         jQuery('#latestDraftsTable tbody').append('&lt;tr&gt;&lt;td&gt;'+item.id+'&lt;/td&gt;&lt;td&gt;' + item.title + '&lt;/td&gt;&lt;td&gt;' + item.date+ '&lt;/td&gt;&lt;/tr&gt;');
      });
   });
   jQuery('#latestDraftsTable').tablesorter({widgets: ['zebra']});
);</pre>
<p>Alguém consegue perceber o erro, ou melhor, a Zebra? Muito difícil. Mas ao rodar o código, não acontecia o esperado: que minha tabela apresentasse o comportamento de uma tabela ordenável que o jQuery UI tablesorter plugin proporciona (ou seja, deu Zebra e não ocorreu a <em>Zebra</em>). Aí eu descobri o problema: a penúltima linha do código nem estava sendo executada&#8230; Seriam Gaps de performance?</p>
<h2>Diferentes paradigmas</h2>
<p>Fosse uma linguagem das antigas qualquer, onde o paradigma procedural imperava, esse código não teria problema, pois cada instrução só seria disparada ao final da anterior. No Javascript, a coisa não é bem assim, ainda mais quando se trata de AJAX -<em><strong>Assynchronous</strong> Jacascript and XML</em> &#8211; uma requisição que é disparada e outra estrutura interna fica encarregada de processar os resultados quando eles chegarem. Ao efetuar a função getJSON, a requisição é disparada, e já passamos para a próxima linha (onde eu chamo o tablesorter na tabela), porém, não deu tempo da requisição JSON retornar e popular a tabela. Resultado: minha tabela fica populada mas não fica ordenável.</p>
<p>Graças a um amigo developer fera em JS, eu consegui perceber isso e reordenaro código de maneira que ele funcionasse como o esperado:</p>
<h3>Código corrigido</h3>
<pre>jQuery().ready(function() {
   jQuery.getJSON('/php/data.drafts.php?l=10&amp;f=json', function(data){
      jQuery.each(data, function(i, item){
         jQuery('#latestDraftsTable tbody').append('&lt;tr&gt;&lt;td&gt;'+item.id+'&lt;/td&gt;&lt;td&gt;' + item.title + '&lt;/td&gt;&lt;td&gt;' + item.date+ '&lt;/td&gt;&lt;/tr&gt;');
      });
      <strong>jQuery('#latestDraftsTable').tablesorter({widgets: ['zebra']});</strong>
   });
);</pre>
<p>Assim, o tablesorter vai ocorrer dentro do <em>callback</em>, logo após ter terminado de ser populada a tabela. Na realidade, os callbacks foram feitos exatamente para situações como essa: <em>quando a coisa vai demorar um pouco e você não tem certeza do quanto&#8230;</em></p>
]]></content:encoded>
			<wfw:commentRss>http://www.thlopes.com/2010/08/republicando-jquery-de-olho-nos-gaps/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Estranho IE 7</title>
		<link>http://www.thlopes.com/2009/06/estranho-ie-7/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=estranho-ie-7</link>
		<comments>http://www.thlopes.com/2009/06/estranho-ie-7/#comments</comments>
		<pubDate>Wed, 10 Jun 2009 19:57:42 +0000</pubDate>
		<dc:creator>Thomas Lopes</dc:creator>
				<category><![CDATA[Desenvolvimento]]></category>
		<category><![CDATA[web]]></category>
		<category><![CDATA[bug]]></category>
		<category><![CDATA[development]]></category>
		<category><![CDATA[internet explorer]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[jquery]]></category>

		<guid isPermaLink="false">http://www.thlopes.com/?p=101</guid>
		<description><![CDATA[Semana retrasada perdi um pouco da minha tarde graças ao IE 7. Descobri, depois de uma boa fuçada, que campos (inputs) em forms que tenham como id as palavras "username", "password" e "email" tem um comportamento um tanto quanto estranho no famoso browser da Micro$oft, se eles forem hidden inputs. Eles ficam impossibilitados de serem alterados via Javascript[bb] (pra que serviria um hidden input que não posso manipular afinal?). <a href="http://www.thlopes.com/2009/06/estranho-ie-7/">Continuar lendo <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Semana retrasada perdi um pouco da minha tarde graças ao IE 7. Descobri, depois de uma boa fuçada, que campos (inputs) em forms que tenham como id as palavras &#8220;username&#8221;, &#8220;password&#8221; e &#8220;email&#8221; tem um comportamento um tanto quanto estranho no famoso browser da Micro$oft, se eles forem hidden inputs. Eles ficam impossibilitados de serem alterados via <a class="bbli" href="http://sledge.boo-box.com/list/page/SmF2YXNjcmlwdF8jI19ib3hfIyNfdGFnZ2luZy10b29sLXdwXyMjXzIzOTM0-60">Javascript<img class="bbic" src="http://boo-box.com/bbli" alt="[bb]" /></a> (pra que serviria um hidden input que não posso manipular afinal?).</p>
<p>Seria um bug? Uma proteção? Uma brecha ou uma tentativa esdrúxula e desesperada de tornar o browser mais seguro para aplicações web? Somente o tio Bill tem a resposta. Como não podemos esperar que ele nos envie por e-mail, vamos a solução: trocar o nome do objeto. No meu caso, não podia renomear o campos pois o processamento dependia do nome fixo dos campos, mas eu ainda podia alterar os ID&#8217;s e manter o nome dos campos intactos. Aí a manipulação com <a class="bbli" href="http://sledge.boo-box.com/list/page/alF1ZXJ5XyMjX2JveF8jI190YWdnaW5nLXRvb2wtd3BfIyNfMjM5MzQ=-56">jQuery<img class="bbic" src="http://boo-box.com/bbli" alt="[bb]" /></a> fica simples e não demanda muitas linhas de código para resolver o problema.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.thlopes.com/2009/06/estranho-ie-7/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

